@charset "UTF-8";

/* ---------------------------------------------------------------- */
/* #region Top Layout  */
/* ---------------------------------------------------------------- */
.top {
  @media (min-width: 769px) {
  }
}

.top__kv {
  @media (min-width: 769px) {
  }
}

.top__tran {
  @media (min-width: 769px) {
  }
}

.top__approach {
  @media (min-width: 769px) {
  }
}
.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 {
  @media (min-width: 769px) {
  }  
}

.top__lineup__list {
  padding-top: 32px;
  padding-bottom: 32px;
  @media (min-width: 769px) {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}

.top__products {
  @media (min-width: 769px) {
  }
}

.top__products__head {
  padding-bottom: 48px;
  @media (min-width: 769px) {
    padding-bottom: 48px;
  }
}

.top__products__media {
  @media (min-width: 769px) {
  }
}

.top__products__list {
  padding-top: 48px;
  padding-bottom: 48px;
  @media (min-width: 769px) {
  }
}

.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;
  @media (min-width: 769px) {
  }
}

.top__philosophy__inner {
  @media (min-width: 769px) {
  }
}

.top__philosophy__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.top__imgNav {
  @media (min-width: 769px) {
  }
}

/* #endregion Top Layout */


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

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

  display: inline-block;
  color: var(--color-offBlack);
  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) {
    color: var(--color-offBlack);
    font-family: var(--font-HankenGrotesk);
    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;
  color: var(--color-offBlack);

  font-family: var(--font-NotoSansJP);
  font-size: 17px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;

  margin-bottom: 10px;
  @media (min-width: 769px) {
    color: var(--color-offBlack);
    font-family: var(--font-NotoSansJP);
    font-size: 17px;
    font-style: normal;
    font-weight: 700;
    line-height: 100%;
    margin-bottom: 12px;
  }
}
.sectionText__row:last-child {
  margin-bottom: 0;
  @media (min-width: 769px) {
    margin-bottom: 0;
  }
}
.sectionText__em {
  color: var(--color-gold);
  @media (min-width: 769px) {
  }
}

/* #endregion Top Common Components */


/* ---------------------------------------------------------------- */
/* #region Top KV  */
/* ---------------------------------------------------------------- */
.kv {
  position: relative;
  @media (min-width: 769px) {
  }
}
.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__typography {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
  }
}
.kv__typographyImg {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
  }
}
.kv__slide {
  position: absolute;
  z-index: auto;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
  }
}
.kv__back {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
  }
}
.kv__front {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
  }
}
.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);
  @media (min-width: 769px) {
  }
}
.kv__photo {
  position: relative;
  margin-bottom: 3px;
  flex: 0 1 102px;
  aspect-ratio: 102/136;
  @media (min-width: 769px) {
    flex: 0 1 98px;
  }
  @media (min-width: 1025px) {
    flex: 0 1 163px;
    margin-bottom: 5px;
  }
}
.kv__focus {
  position: absolute;
  z-index: var(--kv-focus-idx, 0);
  bottom: calc(var(--kv-focus-idx, 0) * 3px);
  right: calc(var(--kv-focus-idx, 0) * 3px);
  display: block;
  width: 100%;
  height: 100%;
  @media (min-width: 769px) {
    bottom: calc(var(--kv-focus-idx, 0) * 5px);
    right: calc(var(--kv-focus-idx, 0) * 5px);
  }
}
.kv__copyJa {
  color: var(--color-blueGray);
  font-family: var(--font-NotoSansJP);
  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-blueGray);
  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-blueGray);
  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 Approach  */
/* ---------------------------------------------------------------- */
.approach {
  @media (min-width: 769px) {
  }
}
.approach__image {
  width: 100%;
  @media (min-width: 769px) {
  }
}

/* #endregion Top Approach */


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

/* トピックス */
.topics {
  @media (min-width: 769px) {
  }
}
.topics__heading {
  margin-bottom: 48px;
  @media (min-width: 769px) {
    margin-bottom: 56px;
  }
}
.topics__list {
  @media (min-width: 769px) {
  }
}

.topics__alone {
  display: flex;
  justify-content: center;
}

.topics__alone img {
  width: 41.527778vw;
}

/* ループスライダー(swiper) */
.swiper.loopSlider {
  position: relative;
  width: 100%;
}

.swiper-wrapper.loopSlider-wrapper {
  margin-bottom: 32px;
}

.swiper-slide.loopSlider-slide img {
  width: 100%;
}

.loopSlider-button-navs {
  pointer-events: none;
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 0;
  width: 100%;
  translate: 0 -50%;
  display: flex;
  justify-content: space-between;

  padding-left: 16px;
  padding-right: 16px;
  @media (min-width: 769px) {
    padding-left: 4.166667vw;
    padding-right: 4.166667vw;
  }
}

.loopSlider-button-prev,
.loopSlider-button-next {
  pointer-events: auto;
  width: 16px;
  height: 26px;
  cursor: pointer;
  @media (min-width: 769px) {
    width: 32px;
    height: 48px;
  }
}

.loopSlider-button-prev svg,
.loopSlider-button-next svg {
  fill: var(--color-offWhite);
  filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, 0.25));

  width: 100%;
  height: auto;
}

.loopSlider-paginations {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
}

.loopSlider-pagination {
  width: 136px !important;
  display: flex;
  gap: 8px;
}

.loopSlider-pagination-bullet {
  flex: 1 1 0%;
  height: 2px;
  background-color: var(--color-offBlack);
  opacity: 0.08;
}
.loopSlider-pagination-bullet-active {
  opacity: 1;
  background: var(--color-gold);
}

/* #endregion Top Topics */


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

/* ベストセラーエリア */
.topBestSeller {
  @media (min-width: 769px) {
  }
}
.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-family: var(--font-NotoSansJP);
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.32px;
  @media (min-width: 769px) {
  }
}

/* #endregion Top Lineup */


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

/* 商品メディア */
.productMedia {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-offBlack);

  margin-top: 26vw;
  padding-top: 36.410256vw;
  padding-bottom: 48px;
  @media (min-width: 769px) {
    margin-top: 0;
    padding-top: 58px;
    padding-bottom: 58px;
  }
}
.productMedia__image {
  position: absolute;
  top: 0%;
  left: 0;
  width: 96%;
  translate: 0 -50%;
  @media (min-width: 769px) {
    position: relative;
    flex: 0 0 50%;
    translate: 0 0%;
  }
}
.productMedia__photo {
  position: relative;
  line-height: 0;
  @media (min-width: 769px) {
    width: 100%;
    height: 389px;
  }
}
.productMedia__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0px 20px 20px 0px;
}
.productMedia__type {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  border-bottom: 1px var(--color-white) solid;

  color: var(--color-offWhite);
  font-family: var(--font-HankenGrotesk);
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.28px;

  padding-left: 16px;
  padding-bottom: 16px;
  margin-bottom: 4.3vw;
  @media (min-width: 769px) {
    font-size: 54px;
    letter-spacing: 0.539px;

    padding-left: 60px;
    padding-bottom: 31px;
    margin-bottom: 31px;
  }
}
.productMedia__body {
  display: flex;
  @media (min-width: 769px) {
    padding-left: 60px;
    flex: 0 0 50%;
  }
}
.productMedia__bodyInner {
  padding-left: 16px;
  padding-right: 16px;
  @media (min-width: 769px) {
    padding-left: 0;
    padding-right: 16px;
    flex: 0 1 550px;
  }
}
.productMedia__heading {
  color: var(--color-offWhite);
  font-family: var(--font-NotoSansJP);
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.44px;
  margin-bottom: 32px;
  @media (min-width: 769px) {
  }
}
.productMedia__sup{
  font-size: 0.4em;
  line-height: 1;
  vertical-align: super;
  display: inline-flex;
  translate: 0 -100%;
}
.productMedia__note {
  color: var(--color-offWhite);
  font-family: var(--font-NotoSansJP);
  font-size: 11px;
  font-style: normal;
  font-weight: 400;
  line-height: 220%;
  @media (min-width: 769px) {
  }
}
.productMedia__text {
  color: var(--color-offWhite);
  font-family: var(--font-NotoSansJP);
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 220%;
  margin-bottom: 40px;
  @media (min-width: 769px) {
  }
}
.productMedia__link {
  margin-bottom: 40px;
  @media (min-width: 769px) {
    max-width: 358px;
  }
}
.productMedia__link:last-child {
  margin-bottom: 0px;
  @media (min-width: 769px) {
    margin-bottom: 0px;
  }
}
 
/* 商品メディア - 反転 */
.productMedia--rev .productMedia__image {
  @media (min-width: 769px) {
    order: 2;
  }
}
.productMedia--rev .productMedia__photo img {
  @media (min-width: 769px) {
    border-radius: 20px 0px 0px 20px;
  }
}
.productMedia--rev .productMedia__body {
  @media (min-width: 769px) {
    padding-left: 0;
    padding-right: 55px;
    justify-content: flex-end;
    order: 1;
  }
}
.productMedia--rev .productMedia__bodyInner {
  @media (min-width: 769px) {
    padding-left: 16px;
    padding-right: 0;
  }
}
.productMedia--rev .productMedia__type {
  @media (min-width: 769px) {
    padding-left: 40px;      
  }
}

/* #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 {
  @media (min-width: 769px) {
  }
}
.newsList__item {
  display: block;
  padding-top: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  @media (min-width: 769px) {
  }
}
.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;
  @media (min-width: 769px) {
  }
}
.newsList__text {
  color: var(--color-offBlack);
  font-feature-settings: "palt" on;
  font-family: var(--font-NotoSansJP);
  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;
  @media (min-width: 769px) {
  }
}

/* #endregion Top News */


/* ---------------------------------------------------------------- */
/* #region Top Philosophy */
/* ---------------------------------------------------------------- */
.topPhilosophy {
  @media (min-width: 769px) {
  }
}

.topPhilosophy__head {
  margin-bottom: 56px;
  @media (min-width: 769px) {
    margin-bottom: 57px;
  }
}

.topPhilosophy__headingEn {
  opacity: 0.1;

  color: var(--color-offBlack);
  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;
  @media (min-width: 769px) {
  }
}
.topPhilosophy__headingJa {
  color: var(--color-offBlack);
  text-align: center;

  font-family: var(--font-NotoSansJP);
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  @media (min-width: 769px) {
  }
}

.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;
  @media (min-width: 769px) {
  }
}

.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 {
  color: var(--color-offBlack);
  font-family: var(--font-NotoSansJP);
  font-size: 15px;
  font-style: normal;
  font-weight: 400;
  line-height: 220%;
  margin-bottom: 40px;
  @media (min-width: 769px) {
  }
}
.topPhilosophy__note {
  color: var(--color-black);
  text-align: center;
  font-family: var(--font-NotoSansJP);
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 220%;

  margin-bottom: 8px;
  @media (min-width: 769px) {
  }
}
.topPhilosophy__link {
  @media (min-width: 769px) {
  }
}

/* #endregion Top Philosophy */

