@charset "UTF-8";
/* =============================================================
    override
============================================================= */

/* =============================================================
    Base
============================================================= */
:root {
  /* color site */
  --color-main: #292624;
  --color-black: var(--color-main);
  --color-primary: #B9984D;
  --color-secondary: #C6B284;
  --color-sale:#CC330E;
  --color-pink: #FAF7F5;
  --color-border: #E0DEDC;
  --grad-1:#FAF6F5;
  --grad-2:#FAF5F2;
  --grad-3:#F0E9E4;
  --theme-backgorund-color-100: linear-gradient(45deg,var(--grad-1) 0%,var(--grad-2) 50%,var(--grad-3) 100%
  );

  --theme-backgorund-color-200: #FAF6F5;
  
  --color-red:#CB001A;
  --color-gray :var(--color-border);
  --color-border-gray:#D0CCC8;
  --color-light-gray:#D0CCC8;
  --color-green:#4DA065;
  --color-light:#B9B9B9;
  --collor-blue: #3E8EDF;
  --color-dark-brown: #513E1E;

  /* font */
  --font-ja-title: var(--font-ja);
  --font-ja: "Noto Sans JP";
  --font-en: "Spectral";
  --font-base: var(--font-ja), sans-serif;
  --font-weight-500: 500;
  --fw-regular: 400;
  --fw-bold: 700;
  /* grid base setting */
  --column-gap : 4.0rem;
  /*common setting */
  --box-shadow: 0 10px 40px rgba(150, 146, 142, 0.06);

  --letter-spacing-base: 0.08em;
  --letter-spacing-lg: 0.12em;
}
body {
  background: var(--theme-backgorund-color-100);
  font-family: var(--font-base);
  color: var(--color-main);
  font-size: 1.4rem;
  letter-spacing: var(--letter-spacing-base);
  line-height: 1.4;
  word-break: break-all;
}
body::after {
  content: "";
  position: fixed; 
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../img/common/body-bg.webp");
  background-size: cover;
  background-position: center 3.0rem;
  background-repeat: no-repeat;
  z-index: -1;
}
a {
  transition: opacity 0.3s ease;
}
a:where(:hover) {
  opacity: 0.5;
}
/* ============================================================================================ utility */
.u-title-base {
  --font-base: var(--font-en), var(--font-ja-title), sans-serif;
  font-family: var(--font-base);
  letter-spacing: 0.02em;
}
.s-header-navBlok__nav.u-title-base a,
.s-header-navBlok__nav.u-title-base span {
  font-family: var(--font-base);
}
/* ============================================================================================ footer */
.s-footer {
  background-color: var(--color-black);
}
/* ============================================================================================ header */
.s-header-userNav {
  background-color: var(--theme-backgorund-color-100);
}
.s-header-wrap {
  column-gap: var(--column-gap);
  border-bottom: none;
}
.s-header-contentsNavBlock {
  column-gap: var(--column-gap);
}
.s-header-contentsNav__navlist {
  column-gap: var(--column-gap);
}
.s-header-contentsNav__navLink > a {
  font-family: var(--font-ja);
  font-size: 1.7rem;
  font-weight: bold;
}
.s-header-categoryNav__head {
  font-size: 1.7rem;
  font-weight: var(--font-weight-500);
}
.s-header-navBlok__nav,
.s-header-wrap {
  background-color: var(--theme-backgorund-color-100);
}
.no-child-category .s-header-categoryNav__head::after {
  content: none;
}
@media screen and (min-width: 768px) {
  .sponly{
    display: none !important;
  }
  .s-header-categoryNav__body .s-header-categoryNav__navLink > a {
    font-size: 1.4rem;
    letter-spacing: var(--letter-spacing-lg);
  }
  .s-header-wrap {
    padding: 0rem 4rem;
  }
  .s-header-categoryNav:hover {
    border-bottom: 3px solid var(--color-primary);
}
}
@media screen and (max-width: 767px) {
  .pconly{
    display: none !important;
  }
  .s-header-navBlok__nav,
  .s-header-userNav {
    background-color: #fff;
  }
  .s-header-categoryNav__head {
    font-size: 1.4rem;
    font-weight: 700;
  }
  .s-header-categoryNav__head,
  .s-header-contentsNav__head {
    font-family: var(--font-ja-title);
    background-color: var(--theme-backgorund-color-100);
  }
  .s-header-contentsNav__navLink > a {
    font-size: 1.4rem;
    font-weight: normal;
  }
}
.s-header-contentsNavBlock__item.pc-only {
  display: none;
}
.s-header-contentsNavBlock__item.sp-only {
  display: block;
}
@media screen and (min-width: 768px) {
  .s-header-contentsNavBlock__item.pc-only {
    display: block;
  }
  .s-header-contentsNavBlock__item.sp-only {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .s-header-contentsNavBlock__item.sp-only .s-header-categoryNav__navLink:last-child {
    margin-bottom: 3.0rem;
  }
  .s-header-categoryNav__navLink:nth-last-of-type(1), .s-header-contentsNav__navLink:nth-last-of-type(1) {
    border-bottom: 1px solid var(--color-border-gray);
}
  .s-header-userNav__navLink:not(:has(a)) {
    border-bottom: none;
  }
}
/* ============================================================================================ footer */
.s-footer__copy-img {
  width: 100%;
  max-width: 1140px;
  margin: 2.5rem auto 0;
  font-size: 1.2rem;
  text-align: left;
}
.s-footer__copy {
  margin-top: 1.5rem;
  color: var(--color-white);
  font-family: var(--font-ja);
}
@media screen and (max-width: 767px) {
  .s-footer__copy-img {
    width: fit-content;
    max-width: auto;
  }
}
/* ============================================================================================ Page */
.p-homeSection__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 4.0rem;
  row-gap: .1rem;
  letter-spacing: var(--letter-spacing-lg);
  font-family: var(--font-en);
  font-size: 4.0rem;
  font-weight: var(--fw-regular);
}
.p-homeSection__title--en {
  letter-spacing: var(--letter-spacing-base);
  font-family: var(--font-ja);
  font-size: 1.4rem;
  color: var(--color-secondary);
}
.p-homeSection__title--has-icon {
  flex-wrap: wrap;
  justify-content: center;
  flex-direction: unset;
}
.p-homeSection__title--icon {
  margin-right: 1.6rem;
}
.p-homeSection__title--has-icon .p-homeSection__title--en {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .p-homeSection__title {
    font-size: 3.2rem;
    margin-bottom: 2.0rem;
  }
  .p-homeSection__title--en {
    font-size: 1.4rem;
  }

}

/* ================================================================== p-homeViewMoreBtn */
button.p-homeViewMoreBtn {
  all: unset;       /* すべてのスタイルをリセット */
  cursor: pointer;
  padding: 1.6rem 0 1.7rem 0;
  width: 24rem;
  font-size: 1.8rem;
  letter-spacing: .012em;
  font-family: var(--font-en);
  border: 1px solid var(--color-main);
  border-radius: 4px;
  position: relative;
  line-height: 1;
}
button.p-homeViewMoreBtn.is-hidden {
  display: none;
}
a.p-homeViewMoreBtn { 
  position: relative;
  padding: 1.6rem 0 1.7rem 0;
  width: 24rem;
  font-size: 1.8rem;
  border: 1px solid var(--color-main);
  letter-spacing: .012em;
  border-radius: 4px;
  font-family: var(--font-en);
  line-height: 1;
}
/* ボタン本体の共通設定 */
a.p-homeViewMoreBtn,
button.p-homeViewMoreBtn {
  overflow: hidden;
  z-index: 1;
  transition: color .8s, border-color .6s;
  transition-timing-function: cubic-bezier(0.41, 0.12, 0.26, 0.97);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  letter-spacing: var(--letter-spacing-lg);
  background: transparent;
}
a.p-homeViewMoreBtn::before,
button.p-homeViewMoreBtn::before {
  content: "";
  width: 130%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--color-primary);
  z-index: -1;
  transform: skewX(45deg) translateX(-150%);
  transition: transform .6s;
  transition-timing-function: cubic-bezier(0.41, 0.12, 0.26, 0.97);
}
.p-homeViewMoreBtn__circle {
  position: absolute;
  width: 2.4rem;
  height: 2.4rem;
  top: 50%;
  transform: translateY(-50%);
  right: 1.0rem;
}
.p-homeViewMoreBtn__icon-common {
  position: relative;
  padding-top: 100%;
  overflow: hidden;
}
.p-homeViewMoreBtn__icon--inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij4gPGcgaWQ9Il8iIGRhdGEtbmFtZT0i77yLIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMzI3IC0yNi4yNSkiPiA8cmVjdCBpZD0iYmFzZSIgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgzMjcgMjYuMjUpIiBmaWxsPSJyZ2JhKDI1NSwyNTUsMjU1LDApIi8+IDxwYXRoIGlkPSJfMiIgZGF0YS1uYW1lPSImZ3Q7IiBkPSJNMCw2LDYsMGw2LDYiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDM0MiAzMi4yNSkgcm90YXRlKDkwKSIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjkyNjI0IiBzdHJva2Utd2lkdGg9IjEiLz4gPC9nPjwvc3ZnPg==");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: inherit;
  transition-duration: 0.4s;
  transition-timing-function: cubic-bezier(0.41, 0.12, 0.26, 0.97);
}
.p-homeViewMoreBtn__icon-base {
  transform: translateX(0);
}
@media (hover: hover) and (pointer: fine) {
  button.p-homeViewMoreBtn:hover,
  a.p-homeViewMoreBtn:hover  { 
    opacity: 1;
  }
  .p-homeViewMoreBtn:hover .p-homeViewMoreBtn__icon-base {
      transform: translateX(5px);
  }
  .p-category-title:hover {
    opacity: .5;
  }
  a.p-homeViewMoreBtn:hover,
  button.p-homeViewMoreBtn:hover {
    color: #fff;
    border-color: var(--color-primary);
    opacity: 1;
  }
  a.p-homeViewMoreBtn:hover::before,
  button.p-homeViewMoreBtn:hover::before {
    transform: skewX(45deg) translateX(-15%);
  }
  .p-homeViewMoreBtn:hover .p-homeViewMoreBtn__icon--inner {
    filter: brightness(0) invert(1);
  }
}
.p-homeViewMoreBtn__icon-common--plus .p-homeViewMoreBtn__icon--inner {
  width: 1.4rem;
  height: .1rem;
  background-color: var(--color-black);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-image: none;
}
.p-homeViewMoreBtn__icon-common--plus .p-homeViewMoreBtn__icon-target {
  transform: translate(-50%, -50%) rotate(90deg);
}
@media (hover: hover) and (pointer: fine) {
  .p-homeViewMoreBtn:hover .p-homeViewMoreBtn__icon-common--plus .p-homeViewMoreBtn__icon-base {
    transform: translate(-50%, -50%) rotate(180deg);
  }
  .p-homeViewMoreBtn:hover .p-homeViewMoreBtn__icon-common--plus .p-homeViewMoreBtn__icon-target {
    transform: translate(-50%, -50%) rotate(270deg);
  }
}
@media screen and (max-width: 767px) {
  a.p-homeViewMoreBtn,
  button.p-homeViewMoreBtn {
    padding: 1.65rem 0;
    font-size: 1.6rem;
    width: 24rem;
  }
  .p-homeViewMoreBtn__circle {
    width: 3.6rem;
    height: 3.6rem;
  }
  .p-homeViewMoreBtn__icon--inner {
    background-size: 1.0rem auto;
  }
}
.p-homeSection {
  padding: 5rem 0;
}
@media screen and (max-width: 767px) {
  .p-page-home {
    overflow-y: hidden;
  }
  .p-homeSection {
    padding: 6.0rem 0;
  }
  .p-homeSection[data-aria="new-arrival"] {
    padding-top: 0;
  }
  .p-page-home {
    padding-bottom: 5.0rem;
  }
  .p-homeSection[data-aria="reccomend"] {
    padding-top: 0;
  }
  .p-homeSection[data-aria="news"] {
    padding-top: 0;
  }
}
.m-homeMainVisual {
  border-bottom: 1px solid var(--color-primary);
  overflow-x: hidden;
}
/* ============================================================================================ p-category */
.p-category-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  align-items: start;
  gap: 2.0rem 3.0rem;
}
.p-category-content {
  box-shadow: var(--box-shadow);
  border-radius: 8px;
  background-color: var(--color-white);
}
.p-category-title {
  display: block;
  position: relative;
  padding: 3.7rem 5.0rem 3.8rem 7.0rem;
  font-size: 1.8rem;
  letter-spacing: var(--letter-spacing-lg);
  font-family: var(--font-ja-title);
  cursor: pointer;
}
.p-category-title__icon {
  width: fit-content;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 2.0rem;
}
summary.p-category-title::before,
summary.p-category-title::after {
  content: "";
  display: block;
  position: absolute;
  top: calc(50% - 1px);
  right: 1.5rem;
  width: 1.4rem;
  height: .2rem;
  background-color: var(--color-primary);
  transition-duration: 0.4s;
  transition-timing-function: cubic-bezier(0.41, 0.12, 0.26, 0.97);
}
summary.p-category-title::before {
  transform: translate(-50%, 0);
}
summary.p-category-title::after {
  transform: translate(-50%, 0) rotate(270deg);
}
/* details[open] summary.p-category-title::before {
  transform: translate(-50%, 0);
}
details[open] summary.p-category-title::after {
  transform: translate(-50%, 0) rotate(360deg);
} */
details[open] summary.p-category-title::before {
  transform: translate(-50%, 0) rotate(45deg);
}
details[open] summary.p-category-title::after {
  transform: translate(-50%, 0) rotate(135deg);
}
.p-category-detail__link {
  display: block;
  padding: 1.25rem 3.0rem;
  font-size: 1.6rem;
  line-height: calc(16/ 14.3);
  color: var(--color-main);
}
.p-category-detail__list {
  padding-bottom: 2.0rem;
}
@media screen and (min-width: 768px) {
  .p-category-detail__list .p-category-detail__link {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .p-category-wrapper {
    grid-template-columns: 1fr;
    gap: 0.6rem;
  }
  .p-category-title {
    padding: 3.1rem 3.2rem 3.3rem 7.0rem;
    font-size: 1.6rem;
    line-height: 1;
  }
  .p-category-title__icon {
    left: 2.0rem;
  }
  .p-category-detail__link {
    font-size: 1.4rem;
  }
  .p-category-detail__list {
    padding-bottom: 1.6rem;
  }
  summary.p-category-title::before,
  summary.p-category-title::after {
    height: .1rem;
  }
}
/* ============================================================================================ 商品 */

.c-productUser-body__title-name,
.c-product-body__title-name {
  font-size: 1.6rem;
  line-height: calc(22.4 / 16);
}
.c-product-body__price {
  font-family: var(--font-en);
}
.c-product-body__price-prime {
  font-size: 1.8rem;
  font-family: var(--font-en);
}
.c-productUser-body__price {
  font-weight: 400;
}
.c-product-body__price-label {
  font-size: 1.2rem;
  margin-right: .5rem;
  line-height: calc(24/12);
  letter-spacing: 0.02em;
  padding: 0 .5rem;
  background-color: #fff;
  border: 1px solid var(--color-main);
  border-radius: 5px;
}
@media screen and (max-width: 767px) {
  .c-product-body__price-prime {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 768px) {
  .c-productUser-body__price {
      font-size: 1.8rem;
  }
}
/* ============================================================================================ p-article-card */
.p-article-card {
  margin-top: 4.0rem;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-rows: 1fr; 
  gap: 3.0rem;
}
.p-article-card__item {
  background-color: #fff;
  border-radius: 8px;
  overflow: hidden;
  height: auto;
  display: list-item;
  animation-name: fadeIn;
  animation-fill-mode:forwards;
  animation-duration:1s;
  box-shadow: var(--box-shadow);
}
.p-article-card__item.is-hidden {
  display: none;
  height: 0;
  overflow: hidden;
}
@keyframes fadeIn{
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-article-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.p-article-card__head img {
  object-fit: cover;
  aspect-ratio: 360/ 240;
}
.p-article-card__body {
  padding: 2.0rem;
  flex-grow: 1;
}
.p-article-card__cat {
  display: inline-block;
  margin-right: .3rem;
  font-size: 1.4rem;
  line-height: calc(24/14);
  letter-spacing: .02em;
  padding: 0 .4rem;
  border-radius: 2px;
  background-color: var(--collor-blue);
  color: #fff;
}
.p-article-card__cat:last-child {
  margin-right: 0;
}
.p-article-card__title {
  margin-bottom: 1.0rem;
  font-family: var(--font-ja-title);
  line-height: calc(28.6/20);
  letter-spacing: var(--letter-spacing-base);
  font-size: 2.0rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* 最大3行 */
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-article-card__text {
  margin-top: 0.07em;
  font-size: 1.5rem;
  line-height: calc(24 /15);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; /* 最大4行 */
  overflow: hidden;
  letter-spacing: var(--letter-spacing-base);
  text-overflow: ellipsis;
}
.p-article-card__foot {
  padding-top: 1.5rem;
  margin-top: auto;
  display: flex;
  justify-content: space-between;
}
.p-article-card__date {
  font-size: 1.4rem;
  color: var(--color-light-gray);
  font-family: var(--font-en);
  letter-spacing: 0.1em;
}
.p-article-card__more-btn {
  position: relative;
  padding-right: 1.8rem;
  font-size: 1.2rem;
  color: var(--color-green);
  font-family: var(--font-en);
  font-weight: bold;
  letter-spacing: 0.2em;
}
.p-article-card__more-btn--icon {
  position:absolute;
  top: 43%;
  transform: translateY(-50%);
  right: 0;
  width: 1.0rem;
  height: 1.0rem;
  mask-image: url('data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213.454%22%20height%3D%2213.452%22%20viewBox%3D%220%200%2013.454%2013.452%22%3E%0A%20%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_2920%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%202920%22%20transform%3D%22translate(-290.15%20-1753.785)%22%3E%0A%20%20%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_3248%22%20data-name%3D%22%E3%83%91%E3%82%B9%203248%22%20d%3D%22M0%2C0H11.862%22%20transform%3D%22translate(302.012%201760.693)%20rotate(180)%22%20fill%3D%22none%22%20stroke%3D%22%23fe903d%22%20stroke-width%3D%222%22%2F%3E%0A%20%20%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_3249%22%20data-name%3D%22%E3%83%91%E3%82%B9%203249%22%20d%3D%22M7857.261%2C1754.5l6.327%2C6.194-6.327%2C5.807%22%20transform%3D%22translate(-7561.438%200)%22%20fill%3D%22none%22%20stroke%3D%22%23fe903d%22%20stroke-width%3D%222%22%2F%3E%0A%20%20%3C%2Fg%3E%0A%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-position: center center;
  mask-size: 100% auto;
  background-color: var(--color-green);
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.41, 0.12, 0.26, 0.97);
}

@media (hover: hover) and (pointer: fine) {
  .p-article-card__link:hover .p-article-card__more-btn--icon {
    right: -5px;
  }
}

@media screen and (max-width: 767px) {
  .p-article-card {
    margin-top: 2.0rem;
    grid-template-columns: 1fr;
    gap: 2.0rem;
    grid-auto-rows:auto;
  }
  .p-article-card__cat {
    font-size: 1.3rem;
  }
  .p-article-card__title {
    margin-bottom: 0.8rem;
    font-size: 1.8rem;
  }
  .p-article-card__text {
    margin-top: 1.0rem;
    font-size: 1.4rem;
    line-height: calc(22.4/14);
  }
  .p-article-card__date {
    font-size: 1.3rem;
  }
  .p-article-card__more-btn {
    font-size: 1.1rem;
  }
}
/* ============================================================================================ swiper setting */
@media screen and (min-width: 768px) {
  .m-homeMainVisual__container {
    padding-inline: calc((100% - 72rem) / 2);
    z-index: 0;
  }
}
.m-homeMainVisual-slideController {
  position: absolute;
  inset: 0; /* スライダー全体にかぶせる */
  z-index: 10; /* 画像より前に表示 */
  pointer-events: none; /* 全体にはクリックを通す */
}
.m-homeMainVisual-slideController__layer {
  position: relative;
  width: 100%;
  height: 100%;
  margin-inline: auto;
  max-width: var(--container-default);
}
.p-page-home .m-homeMainVisual-slideController__prev,
.p-page-home .m-homeMainVisual-slideController__next {
  background-color: var(--color-green);
  z-index: 2;
  pointer-events: auto; 
}
.p-page-home .m-homeMainVisual-slideController__prev > img {
  rotate: 180deg;
}
.p-page-home .m-homeMainVisual-slider__item-picture > img {
  border-radius: 10px;
  width: 100%;
  object-fit: cover;
}
.p-page-home .m-homeMainVisual-slideController__prev {
  left: calc(310 / 1400 * 100%);
}
.p-page-home .m-homeMainVisual-slideController__next {
  right: calc(310 / 1400 * 100%);
  padding-left: 0;
}

.c-productUser-sIcon__item img,
.c-product-sIcon__item img {
  height: 1.8rem;
}

.c-productUser-sIcon__item:not(:has(img)){
  display: none;
}

.m-homeMainVisual-slidePagination {
  display: flex;
}
.m-homeMainVisual-slidePagination__item {
  width: .8rem;
  height: .8rem;
}
.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0;
}
.m-homeMainVisual-slidePagination {
  gap: 1.5rem;
}
.m-homeMainVisual-slidePagination__item.swiper-pagination-bullet-active {
  cursor: default;
  background: var(--color-dark-brown);
}
.m-homeMainVisual__container.swiper {
  overflow: visible;
}
.m-homeMainVisual-slider.swiper-wrapper {
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .m-homeMainVisual__container.swiper { 
    overflow: visible;
  }
  .m-homeMainVisual-slider {
    overflow: visible;
  }
  .m-homeMainVisual-slideController__prev,
  .m-homeMainVisual-slideController__next {
    width: 3.6rem;
    height: 3.6rem;
  }
  .m-homeMainVisual-slideController__prev > img, .m-homeMainVisual-slideController__next > img {
    width: 1.0rem;
  }
  .p-page-home .m-homeMainVisual-slideController__prev {
    left: calc(10 / 375 * 100%);
  }
  .p-page-home .m-homeMainVisual-slideController__next {
    right: calc(30 / 1400 * 100%);
  }
  .m-productLineUser-col3-md4__item {
    width: calc(50% - 1rem);
  }
}


/* ============================================================================================ cicon */
/* liの中にimgがない場合は非表示 */
.c-product-sIcon__item:not(:has(img)) {
  display: none;
}
/* ============================================================================================ News */
@media screen and (min-width: 768px) {
  .p-homeNewsList-body {
    padding: 2.4rem 2rem;
  }
}
.p-homeNewsList-body__time {
  font-size: 1.6rem;
  font-family: var(--font-en);
  letter-spacing: .08em;
  font-weight: var(--fw-regular);
  line-height: 1;
}
.p-homeNewsList__item:nth-child(n+5) {
  display: none;
}
@media screen and (max-width: 767px) {
  .p-homeNewsList-body {
    padding:1.7rem 0 1.5rem;
  }
}
.p-homeNewsList-body__title span {
  font-size: 1.6rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;   /* 2行に制限 */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
}

/* Safari / Chrome / Edge 対応 */
summary::-webkit-details-marker {
  display: none;
}

/* Firefox 対応 */
summary::marker {
  display: none;
}
.s-headerModalBoxFooterBtn .c-btn {
  border-radius: 9999px;
}
/* ============================================================================================ 検索モーダル */
.s-headerModalBoxFooterBtn .c-btn[type="submit"] {
  background-color: var(--color-green);
  border-color:var(--color-green);
}
.s-headerModalBoxHeding__closeBtn{
  color: var(--color-light);
}
@media screen and (min-width: 768px) {
  .s-headerModalBoxFooterBtn__close,
  .s-headerModalBoxFooterBtn__next {
    max-width: 24rem;
  }
  .s-headerModalBoxFooterBtn .c-btn {
    padding: 1.6rem 1rem;
    font-weight: 400;
  }
}
/* ============================================================================================ アカウント */
@media screen and (min-width: 768px) {
  .s-header-userNav__title {
    font-size: 1.5rem;
  }
  .s-header-userNav__navLink > a {
    font-size: 1.4rem;
  }
}

/* カテゴリHTML */
.category-desc {
  position: relative;
  margin-bottom: 10rem;
  padding-bottom: 2rem;
}

.category-desc .category-desc__text-area{
  padding: 2rem 1.5rem 0;
  letter-spacing: 0.025em;
  overflow: hidden;
  max-height: 150px;
  transition: max-height 0.4s ease;
}

.category-desc .category-desc__text-area::after{
  content: "";
  position: absolute;
  bottom: 2rem;
  left: 0;
  right: 0;
  height: 7rem;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), #FEFBF4);
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/* 開いたとき */
.category-desc__text-area.is-open {
  max-height: none;
}
.category-desc__text-area.is-open::after {
  opacity: 0;
}

.category-desc .category-desc__title{
  display: block;
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.5;
  font-family: var(--font-ja-title);
}

.category-desc .category-desc__text{
  display: block;
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 1.75;
}

.category-desc__toggle-button{
  /* reset */
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  
  /* customize */
  position: absolute;
  bottom: -2rem;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: 18rem;
  height: 3.6rem;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 0.3rem 0.4rem;
  background-color: var(--color-green);
  color: var(--color-white);
  font-family: var(--font-ja-title);
  border-radius: 50px;
  margin: 0 auto;
  transition: opacity var(--transition-default);
}

.category-desc-toggle-button__icon{
  position: absolute;
  top: 50%;
  right: 0.4rem;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: auto;
  aspect-ratio: 1/1;
  background-color: var(--color-white);
  border-radius: 50%;
}

.category-desc-toggle-button__icon span{
  position: relative;
  display: block;
  width: 1rem;
  height: 1rem;
}

.category-desc-toggle-button__icon span::before,
.category-desc-toggle-button__icon span::after{
  content: '';
  position: absolute;
  display: block;
  background-color: var(--color-primary);
}

.category-desc-toggle-button__icon span::before{
  width: 100%;
  height: 0.2rem;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.category-desc-toggle-button__icon span::after{
  width: 0.2rem;
  height: 100%;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
}

.category-desc__toggle-button.is-open{
  bottom: -3.5rem;
}

.category-desc__toggle-button.is-open .category-desc-toggle-button__icon span::after{
  transform: translateX(-50%) rotate(90deg);
}

.category-desc.is-short .category-desc__text-area{
  max-height: none;
}

.category-desc.is-short .category-desc__text-area::after{
  display: none;
}

.category-desc.is-short .category-desc__toggle-button{
  display: none;
}

.category-desc__toggle-button:hover{
  opacity: var(--hover-opacity);
}

@media screen and (min-width: 768px) {
 .category-desc {
    margin-bottom: 10rem;
    padding-bottom: 2rem;
  }

  .category-desc .category-desc__text-area{
    padding: 2rem 0 0;
  }

  /* 開いたとき */
  .category-desc .category-desc__title{
    font-size: 1.8rem;
  }

  .category-desc .category-desc__text{
    margin-top: 1rem;
    font-size: 1.5rem;
  }

  .category-desc__toggle-button{
    /* customize */
    width: 24rem;
    height: 4rem;
    font-size: 1.8rem;
    padding: 0.3rem 0.5rem;
  }

  .category-desc-toggle-button__icon{
    right: 0.5rem;
    width: 3rem;
  }

  .category-desc-toggle-button__icon span{
    width: 1.2rem;
    height: 1.2rem;
  }
}

/* マニュアル */
.p-manual .p-manual-lead{
  margin-bottom: 3.4rem;
  font-size: 1.2rem;
  line-height: 2;
}

.p-manual-list{
  padding: 0.7rem 1.6rem;
  background-color: var(--color-white);
}

.p-manual .p-manual-item{
  padding: 1.6rem 0;
}

.p-manual .p-manual-item + .p-manual-item{
  border-top: 1px solid #E9E8E4;
}

.p-manual .p-homeSection__title--sub{
  text-align: center;
  font-size: 2.2rem;
  font-weight: bold;
}

.p-manual .p-manual-item__date{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 10.6rem;
  height: 2.5rem;
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  font-family: var(--font-en);
  background-color: var(--color-secondary);
  font-weight: bold;
}

.p-manual-item__link{
  font-size: 1.4rem;
  text-decoration: underline;
  line-height: 1.6;
}

.p-manual .p-homeViewMoreBtn{
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 4rem auto 5rem;
  width: 24rem;
}

.p-manual .p-homeViewMoreBtn .p-homeViewMoreBtn__circle{
  right: unset;
  left: 1rem;
}

.p-manual .p-homeViewMoreBtn .p-homeViewMoreBtn__icon--inner{
  rotate: 180deg;
}

@media screen and (max-width: 767px) {
  .l-container-wrap{
    flex-direction: column;
  }

  .m-breadcrumb{
    margin: 2rem 0 0;
  }
  
  .p-manual .l-container-sm{
    padding: 0;
  }

  .p-manual .p-homeSection__title{
    margin-bottom: 1rem;
  }

  .p-manual .p-homeSection__title--sub{
    margin-bottom: 1rem;
  }
  .s-header-utilityList__item {
    flex-shrink: 0;
  }
}
@media screen and (min-width: 768px) {
  .m-breadcrumb{
    margin: 2rem 0 6rem;
  }

  .p-manual .p-manual-lead{
    margin-bottom: 7rem;
    font-size: 1.3rem;
  }

  .p-manual-list{
    padding: 2.5rem 8.33333333333%;
  }

  .p-manual .p-manual-item{
    display: flex;
    align-items: flex-start;
    padding: 2.5rem 2rem;
    gap: 4.5rem;
  }

  .p-manual .p-homeSection__title{
    margin-bottom: 3rem;
  }

  .p-manual .p-homeSection__title--sub{
    font-size: 2.7rem;
  }

  .p-manual .p-manual-item__date{
    width: 12.5rem;
    height: 3rem;
    margin-bottom: 0;
    font-size: 1.5rem;
  }

  .p-manual-item__link{
    font-size: 1.6rem;
  }

  .p-manual .p-homeViewMoreBtn{
    margin: 8rem auto 9rem;
    width: 30rem;
  }
}
.s-header-wrap {
  background-color: var(--color-black);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}
.s-header-contentsNavBlock {
  color: var(--color-white);
}
.s-header-wrap__logo {
  width: 16.2rem;
}
.s-header-categoryNav__head {
  font-size: 1.4rem;
  font-weight: var(--fw-regular);
}
.s-header-categoryNav__head::after {
  content: "";
  display: block;
  width: 1.5rem;
  height: 100%;
  margin-left: 1rem;
  background-image: url(../../assets/img/common/icon/icon-arrow-select-plus.svg);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: right calc(50% - 0.2rem);
}
.s-footer-guideNav {
  color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .s-footer-guideNav {
    gap: 1rem 2.4rem;
  }
}
.c-product-head__picture::before {
  padding-top: calc(240/360 * 100%);
}
.c-product-head__image {
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .s-header {
    height: 9.0rem;
  }
  .s-header-contentsNavBlock,
  .s-header-navBlok__nav,
  .s-header-wrap__nav {
    height: 100%;
  }
  .s-header-navBlok {
    height: 100%;
  }
  .s-header-categoryNav__body {
    top: 9.0rem;
  }
  .s-header-miniCart,
  .s-header-userNav {
    top: 9.0rem;
    background-color: #fff;
  }
  .s-header-categoryNav {
    white-space: nowrap;
  }
  .c-product-body__price {
      font-size: 1.8rem;
  }
  .p-homeContentsUnderBtn {
    margin-inline: auto;
    width: fit-content;
  }
  .s-header-wrap {
    height: 9.0rem;
  }
  .p-homeContentsUnderBtn {
    margin-top: 5.8rem;
  }
  
}

.m-homeMainVisual__scroll {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 10;
}

.m-homeMainVisual__scroll-title {
  margin-bottom: 2.0rem;
  font-family: var(--font-en);
  font-weight: var(--fw-bold);
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  color: var(--color-primary);
}
.m-homeMainVisual__scroll-bar {
  position: relative;
  width: 1px;
  height: 9.2rem;
  background: transparent;
  overflow: hidden;
}

.m-homeMainVisual__scroll-bar::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-primary);
  animation: scrollLine 2.0s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

/* アニメーションの定義 */
@keyframes scrollLine {
  0% {
    transform: scaleY(0);
    transform-origin: top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  50.1% {
    transform: scaleY(1);
    transform-origin: bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}
.m-homeMainVisual {
  height: max(calc(100vh - 8.4rem), 66rem);
}
.m-homeMainVisual__title {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 4.6rem;
  position: absolute;
  width: fit-content;
  left: 50%;
  top: calc(50% - 3.0rem);
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
}
.s-header-categoryNav__body {
  color: var(--color-black);
}
.s-header-categoryNav__navLink {
  width: fit-content;
}
.c-product-body__price--sale .c-product-body__price-value {
  color: var(--color-sale);
}
.s-header-categoryNav__body {
  background-color: var(--theme-backgorund-color-200);
}
.s-header__cartCnt {
  right: -0.4rem;
  width: 2.0rem;
  height: 2.0rem;
  background-color: var(--color-primary);
}

  .m-productLineHome {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6.6rem 3.0rem;
  }
  .m-productLineHome__item {
    width: 100%;
  }
  .m-productLineUser-col3-md4 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6.6rem 3.0rem;
  }
  .m-productLineUser-col3-md4__item {
    width: 100%;
  }
  .p-homeSection[data-aria="artcile"] {
    padding-top: 10.0rem;
  }
  .p-homeSection[data-aria="news"] {
    padding-bottom: 0;
  }
  .s-header-categoryNav:hover .s-header-categoryNav__body {
    box-shadow: 0 0 40px rgba(101, 97, 93, 0.05);
  }
  .s-header-categoryNav:hover {
    transition: all cubic-bezier(0.41, 0.12, 0.26, 0.97) 0.2s;
  }
  .s-header-categoryNav:hover .s-header-categoryNav__head::after {
    rotate: 45deg;
  }
@media screen and (max-width: 767px) {
  .s-header-wrap__logo {
    width: 14.8rem;
  }
  .s-header-wrap {
    height: 7.0rem;
    display: flex;
  }
  .s-header-navBlok__openBtn::before, .s-header-navBlok__openBtn::after, .s-header-navBlok__openBtn > span {
    background-color: var(--color-white);
    width: 3.2rem;
    height: 0.1rem;
  }
  .s-header-navBlok__openBtn > span {
    display: none;
  }
  .s-header-wrap__nav {
    width: 5.0rem;
    height: 5.0rem;
    left: 1.5rem;
    top: 1.0rem;
  }
  .s-header-navBlok,
  .s-header-navBlok__openBtn {
    width: 100%;
    height: 100%;
  }
  .s-header-navBlok__openBtn::before {
    top: 2.2rem;

  }
  .s-header-navBlok__openBtn::after {
    top: 2.8rem;
  }
  .s-header-navBlok__openBtn.active::before {
    transform: rotate(-30deg);
    transform-origin: center;
  }
  .s-header-navBlok__openBtn.active::after {
    transform: rotate(30deg);
    transform-origin: center;
    top: 2.3rem;
  }
  .s-header-navBlok__nav, .s-header-userNav {
    background-color: var(--color-pink);
  }
  .s-header-navBlok__nav {
    top: 7.0rem;
  }
  .s-header-categoryNav__head, .s-header-contentsNav__head {
    font-family: var(--font-ja-title);
    background-color: var(--color-black);
  }
  .s-header-categoryNav__navLink {
    width: 100%;
  }
  .s-header-contentsNav__navLink > a {
    color: var(--color-black);
  }
  .m-homeMainVisual__title {
    gap: 5.5rem;
  }
  body::after {
    background-image: url(/assets/img/common/body-bg-sp.webp);
    background-position: center 7.0rem;
  }
  .m-homeMainVisual {
    height: max(calc(100dvh - 7.0rem), 50rem);
  }
  .p-homeContentsUnderBtn .p-homeViewMoreBtn {
    margin-inline: auto;
  }
  .m-productLineHome,
  .m-productLineUser-col3-md4 {
    grid-template-columns: 1fr;
    gap: 2.4rem;
  }
  .c-product-body__price {
    font-size: 1.8rem;
  }
  .s-header-wrap__utility {
    top: 1.5rem;
    right: 1.5rem;
  }
  .m-homeMainVisual__title--main {
    width: 28.7rem;
  }
  .m-homeMainVisual__title--sub {
    width: 23.1rem;
  }
  .m-homeMainVisual__title {
    top: calc(50% - 5.5rem);
  }
  .c-product-body {
    margin-top: 1.8rem;
  }
  .p-homeContentsUnderBtn {
    margin-top: 3.0rem;
  }
  .p-homeViewMoreBtn__circle {
    width: 2.4rem;
    height: 2.4rem;
  }
  .p-homeViewMoreBtn__icon--inner {
    background-size: 2.2rem auto;
  }
  .s-header-userNav__navLink > a {
    padding: 1.6rem 0;
  }
  .s-header-userNav__head {
    margin-bottom: 0.4rem;
  }
}
.c-pager-list-item--active {
  color: var(--color-white);
  background-color: var(--color-primary);
}
.formlp-front-section--header-outer {
  background-color: var(--color-black)!important;
}
.m-productDetailImg-slider__picture {
  aspect-ratio: 570/428;
}
.swiper-lazy-preloader {
  aspect-ratio: 570/428;
}
.swiper-lazy:not(.swiper-lazy-loaded) {
  aspect-ratio: 570/428;
}
@media screen and (max-width: 767px) {
  .m-productDetailImg-slider__picture {
    aspect-ratio: 430/322;
  }
  .swiper-lazy-preloader {
    aspect-ratio: 430/322;
  }
  .swiper-lazy:not(.swiper-lazy-loaded) {
    aspect-ratio: 430/322;
  }
}
