


.slick-dots {display:none !important;}

/* スライダーの表示の縦横比を正方形に固定（CLS防止） */
.item_visual { aspect-ratio: 1 / 1; }

/* Slickの高さを中身に合わせる */
.item_visual .slick-list,
.item_visual .slick-track { height: 100% !important; }

.item_visual .slick-slide {
  height: 100%;
  display: flex !important;
  align-items: center;
  justify-content: center;
}

/* 画像は縦横比が変わっても歪まない */
.item_visual img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* トリミング許容は cover、全体表示は contain */
  display: block;
}

/* 古いブラウザ向けフォールバック（aspect-ratio非対応時） */
@supports not (aspect-ratio: 1 / 1) {
  .item_visual { position: relative; }
  .item_visual::before {
    content: ""; display: block; padding-top: 100%; /* 1:1 */
  }
  .item_visual .slick-list { position: absolute; inset: 0; }
}



/* ===============================
   Common / Base
=============================== */

/* 汎用 */
.ec-productRole__point__info__flex { display: block; }
span.note { display: block; font-size: 14px; } /* 注釈テキストの最小サイズ調整 */

/* モーダル（PC/SP共通レイアウト） */
.ec-productRole__modal{
  border-radius: 48px;
  border: 1px solid #000;
  background: #fff;
  display: flex;
  padding: 10px 15px;
  color: #000;
  line-height: 1;
  width: fit-content;
  font-size: 14px;
  font-weight: 700;
  column-gap: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.ec-productRole__modal:hover{ background:#f2f2f2 !important; }

/* Remodal（モーダル周り） */
.remodal.remodal-is-initialized.remodal-is-opened { background: none; }

/* ===============================
   PC (>=768px)
=============================== */
@media only screen and (min-width: 768px) {

  /* ---- Product Role : Typography / Layout ---- */
  .ec-productRole{
    margin: 0 auto 120px;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.4;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: unset;       /* テーマ側のmax-width制限を解除 */
  }

  .ec-productRole__price2 .ec-price__price2{
    font-size: 30px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    color: #000;
  }
  .ec-productRole__price2 .ec-price2__tax{
    font-weight: 500;
    font-size: 14px;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    color: #000;
  }
  .ec-productRole__price2 p{ margin-top: 20px; line-height: 1.8; }

  .ec-productRole .ec-productRole__textBlock__content.feature p{
    font-size: 16px;
    margin-bottom: 32px;
    line-height: 1.8;
    font-weight: 500;
  }

  .ec-productRole__point__block{ margin-bottom: 120px; }

  .ec-productRole__for .slide-item dl dt{ font-size:14px; letter-spacing:.05em; }

  .ec-productRole__others .ec-productRole .product-row .product-card .product-content h3,
  .ec-productRole__others .ec-productRole .product-row .product-card .product-content .h3{
    font-size: 18px;
    letter-spacing: .05em;
    line-height: 1.8;
  }
  .ec-productRole__others .ec-productRole .product-row .product-card .description-text{
    font-size: 16px;
    letter-spacing: .05em;
    line-height: 1.8;
    text-align: center;
  }

  .ec-productRole__point__info p{
    font-weight: 500;
    font-size: 16px;
    line-height: 2.2;
    letter-spacing: .05em;
  }
  .ec-productRole__point__info__flex dl dt{
    font-size: 18px;
    font-weight: 700;
    color: #C3976F;
    margin-bottom: 10px;
  }
  .ec-productRole__point__info__flex dl dd{
    font-size: 14px;
    line-height: 1.8;
    letter-spacing: .05em;
    font-weight: 500;
  }
  .ec-productRole__point__info h3,
  .ec-productRole__point__info .h3{ font-size:18px; letter-spacing:.05em; line-height:1.8; }
  .ec-productRole__point__info h2,
  .ec-productRole__point__info .h2{ font-size:36px; margin-bottom:45px; letter-spacing:.05em; }

  /* ---- Slider / Dots ---- */
  .slick-dots{ display:none !important; }
  .ec-sliderItemRole{ border-bottom: unset; }
  .ec-sliderItemRole .item_nav{
    display:flex; justify-content:flex-start; flex-wrap:wrap;
    margin-bottom:0; column-gap:18.9px;
  }

  /* ---- Others ---- */
  .front_page__intro2__note{
    border-top:1px solid #D9D9D9; border-bottom:1px solid #D9D9D9;
    padding:16px 0; margin-top:48px; font-size:12px; font-weight:500; line-height:1.7;
  }
}

/* ===============================
   Tablet Portrait (768?1024 / portrait)
=============================== */
@media (min-width: 768px) and (max-width: 1024px) and (orientation: portrait){
  .br-pc{ display:none; }

  .ec-productRole__for .slide-item{ padding:0 15px; }
  .ec-productRole__for .slide-item dl dd{ font-size:22px; }

  span.note{ font-size:12px; } /* PC��14px����㏑�� */

  .ec-productRole__point__block figure{ width:40%; }
  .ec-productRole__point__info{ width:60%; margin-bottom:0; }

  .ec-productRole__point__info h2,
  .ec-productRole__point__info .h2{ font-size:28px; }

  .ec-productRole__textBlock__content{ margin-bottom:80px; }
  .ec-productRole .ec-productRole__description{ font-size:22px; }
}

/* ===============================
   SP (<=767px)
=============================== */
@media (max-width: 767px){
  .br-pc{ display:none; }

  /* ---- Slider Thumbs Grid ---- */
  .ec-sliderItemRole .item_nav{
    display:grid; grid-template-columns:repeat(5,1fr);
    gap:8px; margin-bottom:0;
  }
  .ec-sliderItemRole .slideThumb{
    max-width:none; aspect-ratio:1 / 1; margin-bottom:0;
    cursor:pointer; overflow:hidden; border-radius:16px;
  }
  .ec-sliderItemRole .slideThumb img,
  .ec-sliderItemRole .slideThumb .product-img{
    width:100%; height:100%; object-fit:cover; display:block;
  }
  .ec-sliderItemRole .item_visual .slick-slide{ margin-bottom:0; }

  /* ---- Product Role (SP) ---- */
  .ec-productRole{ margin-bottom:0; }
  .ec-productRole .ec-productRole__textBlock__title{ margin-top:40px; }
  .ec-productRole__textBlock__content{ margin-bottom:80px; }
    .ec-productRole .ec-productRole__textBlock__content.feature p { font-size:14px; line-height: 1.8; }
    .ec-productRole .ec-productRole__textBlock__content h3,
     .ec-productRole .ec-productRole__textBlock__content h3, .ec-productRole .ec-productRole__textBlock__content .h3 { font-size:16px; margin-bottom: 16px; }
     .ec-productRole__textBlock__content__materialall { font-size: 14px; line-height: 1.8;}
  .ec-productRole .ec-productRole__description{ font-size:18px; line-height:1.8; }
  .ec-productRole .ec-productRole__tag{ font-size:14px; }
  .ec-productRole .ec-productRole__textBlock__content.ingredients .ec-productRole__textBlock__content__wrap > div table td { font-size:14px; }
.front_page__intro2__note { margin-top:0px; }
span.note {font-size: 12px;}
  /* ---- Point Info ---- */
  .ec-productRole__point__info h3,
  .ec-productRole__point__info .h3{ font-size:18px; line-height:1.8; }
  .ec-productRole__point__info h2,
  .ec-productRole__point__info .h2{ font-size:22px; }
  .ec-productRole__point__info p{
    font-size:14px; font-weight:500; line-height:2.2; letter-spacing:.05em;
  }
  .ec-productRole__point__info__flex dl dt{ margin-bottom:5px; }
  .ec-productRole__point__info__flex dl dd{ font-size:14px; font-weight:500;line-height: 1.8; }

  /* ---- For Slider Item ---- */
  .ec-productRole__for .slide-item p{ font-size:16px; }

  /* ---- Notes ---- */
  span.note{ margin-top:5px; } /* �ǋL����SP�ŕt�^ */

  /* ---- Footer ---- */
  .ec-footerRole .ec-footerRole__products dd ul li a{ font-size:14px; text-wrap-mode: nowrap; }
  .ec-footerRole .ec-footerRole__logo img{ width:60%; margin:0 auto; }
  .ec-footerRole .ec-footerRole__logo{ margin-bottom:60px; }
}