@charset "UTF-8";

/* ---------------------------------------------------------------- */
/* #region Top Layout  */
/* ---------------------------------------------------------------- */
.top {
}
.top__kv {
}
.top__tran {
  position: relative;
}
.top__benefit {
  background-color: var(--color-offBlack);
}
.top__topics {
  padding-top: 80px;
  @media (min-width: 769px) {
    padding-top: 80px;
  }
}
.top__bestSeller {
  padding-top: 96px;
  padding-bottom: 80px;
  @media (min-width: 769px) {
    padding-top: 130px;
    padding-bottom: 90px;
  }
}
.top__lineup {
  margin-bottom: 160px;
  @media (min-width: 769px) {
    margin-bottom: 80px;
  }
}
.top__lineup__head {
  padding-top: 48px;
  padding-bottom: 40px;
  @media (min-width: 769px) {
    padding-top: 56px;
    padding-bottom: 40px;
  }
}
.top__lineup__copy {
  padding-bottom: 48px;
  @media (min-width: 769px) {
    padding-bottom: 60px;
  }
}
.top__lineup__hero {
}
.top__lineup__list {
  padding-top: 32px;
  padding-bottom: 32px;
  @media (min-width: 769px) {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
.top__products {
}
.top__products__head {
  padding-bottom: 48px;
  @media (min-width: 769px) {
    padding-bottom: 48px;
  }
}
.top__products__media {
}
.top__products__list {
  padding-top: 48px;
  padding-bottom: 48px;
}
.top__products__listInner {
  @media (min-width: 769px) {
    padding-left: 42px;
    padding-right: 42px;
  }
}
.top__news {
  padding-top: 80px;
  padding-bottom: 100px;
  @media (min-width: 769px) {
    padding-top: 108px;
    padding-bottom: 303px;
  }
}
.top__philosophy {
  position: relative;
  padding-top: 60px;
  padding-bottom: 53px;
  @media (min-width: 769px) {
    padding-top: 128px;
    padding-bottom: 128px;
  }
}
.top__philosophy__bg {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.top__philosophy__inner {
}
.top__philosophy__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top__imgNav {
}

/* #endregion Top Layout */


/* ---------------------------------------------------------------- */
/* #region Top Common Components */
/* ---------------------------------------------------------------- */

/* セクション見出し */
.sectionHeading {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;

  display: inline-block;
  font-family: var(--font-HankenGrotesk);
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: 100%;
  letter-spacing: 0.6px;
  @media (min-width: 769px) {
    font-size: 40px;
    letter-spacing: 0.8px;
  }
}
.sectionHeading--product {
  font-size: 31px;
  letter-spacing: 0.62px;
  @media (min-width: 769px) {
    font-size: 42px;
    letter-spacing: 0.84px;
  }
}

/* セクションテキスト */
.sectionText {
}
.sectionText__row {
  display: block;

  font-size: 17px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;

  margin-bottom: 10px;
  @media (min-width: 769px) {
    margin-bottom: 12px;
  }
}
.sectionText__row:last-child {
  margin-bottom: 0;
  @media (min-width: 769px) {
    margin-bottom: 0;
  }
}
.sectionText__em {
  color: var(--color-gold);
}

/* #endregion Top Common Components */


/* ---------------------------------------------------------------- */
/* #region Top KV  */
/* ---------------------------------------------------------------- */
.kv {
  position: relative;
}
.kv_canvas {
  pointer-events: none;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__bg {
  position: relative;
  z-index: -1;
  top: 0;
  left: 0;
  aspect-ratio: 390/603;
  width: 100%;
  @media (min-width: 769px) {
    aspect-ratio: 1440/810;
  }
}
.kv__gradBridge {
  position: absolute;
  z-index: 0;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 51.282051vw;
  background: linear-gradient(0deg, var(--color-offBlack) 0%, rgba(42, 39, 39, 0.00) 100%);
  @media (min-width: 769px) {
    height: 13.888889vw;
  }
}
.kv__typography {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__typographyImg {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__slide {
  position: absolute;
  z-index: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__back {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__front {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.kv__contents {
  position: absolute;
  z-index: 1;
  left: 0;
  bottom: 0;
  width: 100%;
}
.kv__body {
  display: flex;
  gap: 17px;
  align-items: flex-end;
  padding-bottom: 18px;
  @media (min-width: 769px) {
    gap: 28px;
    padding-bottom: 32px;
  }
}
.kv__foot {
  width: 100%;
  border-top: 1px solid var(--color-white);
}
.kv__photo {
  position: relative;
  flex: 0 1 102px;
  aspect-ratio: 102/136;
  @media (min-width: 769px) {
    flex: 0 1 98px;
  }
  @media (min-width: 1025px) {
    flex: 0 1 163px;
  }
}
.kv__focus {
  position: absolute;
  z-index: 0;
  bottom: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
    bottom: 0;
    right: 0;
  }
}
.kv__copyJa {
  color: var(--color-lightGray);
  font-style: normal;
  font-weight: 500;
  line-height: 140%;
  font-size: 5.641026vw;
  letter-spacing: 0.451282vw;
  margin-bottom: 10px;
  @media (min-width: 769px) {
    font-size: 21px;
    letter-spacing: 1.68px;
    margin-bottom: 12px;
  }
  @media (min-width: 1025px) {
    font-size: 35px;
    letter-spacing: 2.8px;
    margin-bottom: 18px;
  }
}
.kv__copyEn {
  color: var(--color-lightGray);
  font-family: var(--font-HankenGrotesk);
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  font-size: 10.769231vw;
  letter-spacing: -0.107692vw;
  white-space: nowrap;
  @media (min-width: 769px) {
    font-size: 40px;
    letter-spacing: -0.4px;
  }
  @media (min-width: 1025px) {
    font-size: 67px;
    letter-spacing: -0.67px;
  }
}
.kv__heading {
  position: relative;
  color: var(--color-lightGray);
  font-family: var(--font-HankenGrotesk);
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  font-size: 3.333333vw;
  letter-spacing: 0.033333vw;
  padding-top: 18px;
  padding-bottom: 18px;
  @media (min-width: 769px) {
    font-size: 13px;
    letter-spacing: 0.13px;
    padding-top: 24px;
    padding-bottom: 24px;
  }
}
/* Top KV - 状態 */
.kv__front {
  opacity: 0;
  transition: opacity 0.3s 0.4s;
}
.kv__back {
  opacity: 0;
  transition: opacity 0.3s 0.4s;
}
.kv__slide.active .kv__front {
  opacity: 1;
  transition: opacity 0.3s 0.4s linear;
}
.kv__slide.active .kv__back {
  opacity: 1;
  transition: opacity 0.3s 0.4s ease-out;
}
.kv__typographyImg {
  opacity: 0;
  transform: translate3d(0, 22%, 0);
  transition:
    opacity 2s linear,
    transform 1.5s cubic-bezier(0.25, 1, 0.5, 1);
}
html[data-state-load="complete"] .kv__typographyImg {
  opacity: 1;
  transform: translate3d(0, 0%, 0);
}

/* #endregion Top KV */


/* ---------------------------------------------------------------- */
/* #region Top BENEFIT  */
/* ---------------------------------------------------------------- */
.benefit {
  position: relative;
  padding-top: 14.615385vw;
  padding-bottom: 83.333333vw;
  @media (min-width: 769px) {
    padding-top: 11.111111vw;
    padding-bottom: 9.375vw;
  }
}
.benefit__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.benefit__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.benefit__head {
  position: relative;
}
.benefit__body {
  display: flex;
  justify-content: space-between;
  padding-left: 13.076923vw;
  @media (min-width: 769px) {
    padding-left: 4.166667vw;
  }
}
.benefit__heading {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;

  display: flex;
  align-items: center;

  color: var(--color-offWhite);
  font-family: var(--font-HankenGrotesk);
  font-style: normal;
  font-weight: 600;
  line-height: 100%;

  transform-origin: left top;
  rotate: 90deg;

  font-size: 3.333333vw;
  letter-spacing: 0.266667vw;
  translate: 6.153846vw 0;
  @media (min-width: 769px) {
    translate: 1.666667vw 0;
    font-size: 0.902778vw;
    letter-spacing: 0.072222vw;
  }
}
.benefit__heading::before{
  display: inline-block;
  content: "";
  background-color: var(--color-gold);
  width: 1.025641vw;
  height: 6.153846vw;
  margin-right: 2.051282vw;
}
@media (min-width: 769px) {
  .benefit__heading::before{
    width: 0.277778vw;
    height: 1.666667vw;
    margin-right: 0.555556vw;
  }
}

.benefit__image {
  position: relative;
}
.benefit__photo {
  position: relative;
  z-index: 1;
  width: 76.666667vw;
  height: auto;
  border-radius: 10px 0 0 10px;
  @media (min-width: 769px) {
    width: 58.263889vw;
    height: auto;
    border-radius: 10px 0 0 10px;
  }
}
.benefit__rad {
  position: absolute;
  z-index: 0;
  top: 67.692308vw;
  left: -7.692308vw;
  width: 70vw;
  height: 70vw;
  @media (min-width: 769px) {
    top: 6.944444vw;
    left: -20.694444vw;
    width: 25.902778vw;
    height: 25.902778vw;
  }
}
.benefit__chart {
  position: absolute;
  z-index: 2;
  top: 53.589744vw;
  left: -19.487179vw;
  width: 92.307692vw;
  height: 96.410256vw;
  @media (min-width: 769px) {
    top: 1.805556vw;
    left: -30vw;
    width: 48.611111vw;
    height: 34.722222vw;
  }
}
.benefit__chart img {
  width: 100%;
  height: auto;
}
.benefit__slash {
  position: absolute;
  z-index: 1;
  right: 0;
  bottom: -81vw;
  width: 72.307692vw;
  height: auto;
  @media (min-width: 769px) {
    bottom: -9.375vw;
    width: 35.555556vw;
  }
}

/* #endregion Top BENEFIT */


/* ---------------------------------------------------------------- */
/* #region Top Topics  */
/* ---------------------------------------------------------------- */

/* トピックス */
.topics {
}
.topics__heading {
  margin-bottom: 48px;
  @media (min-width: 769px) {
    margin-bottom: 56px;
  }
}
.topics__list {
}
.topics__alone {
  display: flex;
  justify-content: center;
}
.topics__alone img {
  width: 41.527778vw;
}

/* トピックスバナー */
.topicsBanner {
  width: 100%;
  height: auto;
}

/* #endregion Top Topics */


/* ---------------------------------------------------------------- */
/* #region Top Best Seller  */
/* ---------------------------------------------------------------- */

.topBestSeller {
}
.topBestSeller__heading {
  padding-left: 16px;
  margin-bottom: 48px;
  @media (min-width: 769px) {
    padding-left: 0;
    margin-bottom: 56px;
  }
}
.topBestSeller__list {
  @media (min-width: 769px) {
    padding-left: 40px;
    padding-right: 40px;
  }
}
/* #endregion Top Best Seller */


/* ---------------------------------------------------------------- */
/* #region Top Lineup  */
/* ---------------------------------------------------------------- */

/* ライナップヘッドエリア */
.lineupHead {
  position: relative;
  @media (min-width: 769px) {
  }
}
.lineupHead__bg {
  overflow: hidden;
  aspect-ratio: 390/550;
  @media (min-width: 769px) {
    aspect-ratio: 1440/550;
  }
}
.lineupHead__bg img {
  width: 100%;
  height: 100%;
}
.lineupHead__body {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: flex-end;

  padding-left: 22px;
  padding-right: 22px;
  padding-bottom: 38px;
  @media (min-width: 769px) {
    align-items: center;
    justify-content: center;
  }
}
.lineupHead__en {
  color: var(--color-offWhite);
  font-family: var(--font-HankenGrotesk);
  font-size: 40px;
  font-style: normal;
  font-weight: 600;
  line-height: 110%;
  letter-spacing: 1.6px;
  margin-bottom: 16px;
  @media (min-width: 769px) {
    margin-bottom: 40px;
  }
}
.lineupHead__ja {
  color: var(--color-offWhite);
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.32px;
  @media (min-width: 769px) {
  }
}

/* ラインナップグリッド */
.lineupGrid {
  display: flex;
  gap: 16px;
  padding-left: 16px;
  padding-right: 16px;
  @media (min-width: 769px) {
    gap: 40px;
    padding-left: 0px;
    padding-right: 0px;
  }
}
.lineupGrid__item {
  flex: 0 0 150px;
  @media (min-width: 769px) {
    flex: 0 0 254px;
  }
}
.lineupGrid__item img {
  width: 100%;
}
/* ラインナップグリッド - 状態:スクロールスライダー無効 */
.c-scrollSlider.disabled .lineupGrid {
  justify-content: center;
  @media (min-width: 769px) {
    justify-content: center;
  }
}

/* #endregion Top Lineup */


/* ---------------------------------------------------------------- */
/* #region Top Products */
/* ---------------------------------------------------------------- */

/* #endregion Top Products */


/* ---------------------------------------------------------------- */
/* #region Top News  */
/* ---------------------------------------------------------------- */

/* ニュースエリア　*/
.topNews {
  @media (min-width: 769px) {
    display: flex;
    justify-content: space-between;
    gap: 60px;
  }
}
.topNews__heading {
  margin-bottom: 48px;
  @media (min-width: 769px) {
    flex: 0 0 116px;
  }
}
.topNews__body {
  @media (min-width: 769px) {
    flex: 0 1 766px;
  }
}
.topNews__list {
  margin-bottom: 48px;
  @media (min-width: 769px) {
  }
}
.topNews__link {
  display: flex;
  justify-content: center;
  @media (min-width: 769px) {
    justify-content: flex-end;
  }
}

/* ニュース一覧 */
.newsList {
}
.newsList__item {
  display: block;
  padding-top: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-black-alpha);
}
.newsList__item:last-child {
  border-bottom: none;
}
.newsList__date {
  color: var(--color-gold);
  font-family: var(--font-HankenGrotesk);
  font-size: 15px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.45px;
  margin-bottom: 8px;
}
.newsList__text {
  font-feature-settings: "palt" on;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 160%;

  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow-wrap: break-word;
}

/* #endregion Top News */


/* ---------------------------------------------------------------- */
/* #region Top Philosophy */
/* ---------------------------------------------------------------- */
.topPhilosophy {
}
.topPhilosophy__head {
  margin-bottom: 56px;
  @media (min-width: 769px) {
    margin-bottom: 57px;
  }
}
.topPhilosophy__headingEn {
  opacity: 0.1;

  text-align: center;
  font-family: var(--font-HankenGrotesk);
  font-size: 42px;
  font-style: normal;
  font-weight: 700;
  line-height: 95%;
  letter-spacing: 0.42px;
  margin-bottom: 24px;
}
.topPhilosophy__headingJa {
  text-align: center;

  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
}
.topPhilosophy__obi {
  display: inline-block;
  background: rgba(184, 153, 107, 0.25);
  padding: 2px 4px 4px 4px;

  color: var(--color-gold);
  font-weight: 900;
  margin-right: 4px;
}
.topPhilosophy__body {
  @media (min-width: 769px) {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
  }
}
.topPhilosophy__image {
  margin-bottom: 80px;
  @media (min-width: 769px) {
    flex: 0 1 358px;
  }
}
.topPhilosophy__image img {
  width: 100%;
}
.topPhilosophy__contents {
  @media (min-width: 769px) {
    flex: 0 1 330px;
  }
}
.topPhilosophy__text {
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 220%;
  margin-bottom: 40px;
}
.topPhilosophy__note {
  color: var(--color-black);
  text-align: center;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 220%;
  margin-bottom: 8px;
}
.topPhilosophy__link {
}

/* #endregion Top Philosophy */

