/* =========================================================
   HOME: ランキング（PDP特徴カード流用）— PLP準拠・見出し固定
   対象限定: body.home + #front-ranking
   ========================================================= */

/* セクション：コンテナ幅・左右ガター */
body.home section#front-ranking.pdp-section--ranking {
  --cw: var(--container-width, 1320px);
  --cg: var(--container-gutter, 24px);
  max-width: var(--cw);
  margin: clamp(32px, 6vw, 72px) auto;
  padding-left: var(--cg);
  padding-right: var(--cg);
}

/* ===== 見出し（Galleryと同仕様：上=英字/下=日本語） ===== */
body.home section#front-ranking.pdp-section--ranking h2.pdp-section__title {
  position: relative;
  border-bottom: none !important;
  padding-left: 4px;       /* Gallery準拠 */
  padding-right: 0;
  margin: 2rem 0 2.5rem;   /* Gallery準拠 */
  font-size: clamp(13px, 1.2vw, var(--fs-sm, 14px)) !important; /* 下段=日本語 */
  font-weight: var(--fw-regular, 400) !important;
  color: var(--c-fg-muted, #6b7280);
  line-height: 1.4 !important;
  letter-spacing: normal;
}

/* 先行の「content:none」を打ち消して英字を大きく表示（最終上書き） */
body.home section#front-ranking.pdp-section--ranking h2.pdp-section__title::before {
  content: attr(data-en) !important;                 /* 上段=英字 */
  display: block !important;
  font-size: clamp(var(--fs-xl, 32px), 5vw, 56px);   /* Gallery準拠 */
  line-height: 1.1;
  font-weight: var(--fw-regular, 400);
  letter-spacing: .01em;
  color: rgba(17, 17, 17, .88);
  margin-bottom: .75rem;
}

/* after は使用しない */
body.home section#front-ranking.pdp-section--ranking h2.pdp-section__title::after {
  content: none !important;
  display: none !important;
}

/* タブヘッダ（存在時の微調整） */
body.home section#front-ranking.pdp-section--ranking .frontTabs__head {
  margin: 8px 0 12px;
  position: relative;
}
body.home section#front-ranking.pdp-section--ranking .frontTabs__underline {
  position: absolute;
  left: 0;
  bottom: -2px;
  height: 2px;
  width: 0;
  background: currentColor;
  opacity: .15;
  pointer-events: none;
}

/* スライダー外枠（右フルブリード＋ガター） */
body.home section#front-ranking.pdp-section--ranking .featCards.swiper,
body.home section#front-ranking.pdp-section--ranking .pdp-features-swiper {
  margin-right: calc(50% - 50vw + var(--container-gutter, 24px));
  padding-right: var(--container-gutter, 24px);
  padding-left: 0;
  overflow: hidden;
}

/* カード体裁 */
body.home section#front-ranking.pdp-section--ranking .featCards__media {
  position: relative;
  background: #f8f9fa;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

/* Swiper初期化前の一時表示を横並び固定にする */
body.home section#front-ranking.pdp-section--ranking .featCards.swiper:not(.swiper-initialized) {
  display: flex;
  gap: var(--space-6);
  overflow: hidden;
}
body.home section#front-ranking.pdp-section--ranking .featCards.swiper:not(.swiper-initialized) > .featCards__item {
  flex: 0 0 41%;
  max-width: 41%;
}
@media (max-width: 1024px) {
  body.home section#front-ranking.pdp-section--ranking .featCards.swiper:not(.swiper-initialized) > .featCards__item {
    flex-basis: 44%;
    max-width: 44%;
  }
}
@media (max-width: 768px) {
  body.home section#front-ranking.pdp-section--ranking .featCards.swiper:not(.swiper-initialized) > .featCards__item {
    flex-basis: 82%;
    max-width: 82%;
  }
}
body.home section#front-ranking.pdp-section--ranking .featCards__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
body.home section#front-ranking.pdp-section--ranking .featCards__title {
  margin-top: .5rem;
  font-size: .875rem;
  font-weight: 400;
  line-height: 1.5;
}
/* 価格（任意） */
body.home section#front-ranking.pdp-section--ranking .text-sm {
  font-size: .875rem;
  line-height: 1.6;
}

/* ランキング順位バッジ（1〜3位は色分け） */
body.home section#front-ranking.pdp-section--ranking .ranking-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  line-height: 28px;
  border-radius: 50%;
  font-size: .875rem;
  font-weight: 600;
  background: #ccc;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}
body.home section#front-ranking.pdp-section--ranking .ranking-badge.rank-1 { background: #FFD700; color: #111; }
body.home section#front-ranking.pdp-section--ranking .ranking-badge.rank-2 { background: #C0C0C0; color: #111; }
body.home section#front-ranking.pdp-section--ranking .ranking-badge.rank-3 { background: #CD7F32; color: #fff; }

/* Swiper ドット非表示／矢印位置調整 */
body.home section#front-ranking.pdp-section--ranking .swiper-pagination { display: none !important; }

/* ===== 幅指定：PLP と同挙動 ===== */
@media (min-width: 768px) {
  /* PC/タブレットは常に 20% 幅 */
  body.home section#front-ranking.pdp-section--ranking .featCards.swiper .swiper-slide {
    width: 20% !important;
    flex: 0 0 20% !important;
    max-width: none !important;
    height: auto;
    box-sizing: border-box;
  }
}
@media (max-width: 767px) {
  /* モバイルは右フル解除＋“1枚強”（82%）表示、矢印非表示 */
  body.home section#front-ranking.pdp-section--ranking .featCards.swiper,
  body.home section#front-ranking.pdp-section--ranking .pdp-features-swiper {
    margin-right: 0 !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  body.home section#front-ranking.pdp-section--ranking .featCards.swiper .swiper-slide {
    width: 82% !important;
    flex: 0 0 82% !important;
    max-width: none !important;
  }
  body.home section#front-ranking.pdp-section--ranking .swiper-button-prev.pdp-feat__navPrev,
  body.home section#front-ranking.pdp-section--ranking .swiper-button-next.pdp-feat__navNext {
    display: none !important;
  }
}

/* ===== Tabs ラッパーがある場合も同仕様で上書き ===== */
body.home .frontRankingTabs .featCards.swiper,
body.home .frontRankingTabs .pdp-features-swiper {
  margin-right: calc(50% - 50vw + var(--container-gutter, 24px));
  padding-right: var(--container-gutter, 24px);
  padding-left: 0;
}
@media (max-width: 767px) {
  body.home .frontRankingTabs .featCards.swiper,
  body.home .frontRankingTabs .pdp-features-swiper {
    margin-right: 0 !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  body.home .frontRankingTabs .featCards.swiper .swiper-slide {
    width: 82% !important;
    flex: 0 0 82% !important;
    max-width: none !important;
  }
}

/* ===== アクセシビリティ微調整 ===== */
body.home section#front-ranking.pdp-section--ranking .featCards[role="list"] { list-style: none; margin: 0; padding: 0; }
body.home section#front-ranking.pdp-section--ranking .featCards__item[role="listitem"] { outline: none; }

/* コンパクト見た目（スクショ相当） */
.frontTabs__head.frontTabs--compact{
  position:relative; display:flex; align-items:center; gap:20px;
  color:var(--c-fg-muted,#6b7280); font-size:14px; line-height:1.6;
  padding-bottom:8px;
}
.frontTabs__head.frontTabs--compact .frontTabs__tab{
  appearance:none; border:0; background:transparent; padding:0 2px; cursor:pointer;
  color:inherit; font:inherit; opacity:.9;
}
.frontTabs__head.frontTabs--compact .frontTabs__tab.is-active{
  color:var(--c-brand,#1f4063); opacity:1; font-weight:600;
}
.frontTabs__head.frontTabs--compact .frontTabs__sep{
  width:1px; height:14px; background:currentColor; opacity:.2; display:inline-block;
}
.frontTabs__head.frontTabs--compact .frontTabs__underline{
  position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--c-brand,#1f4063); border-radius:2px;
  transition:width .25s ease, left .25s ease;
  pointer-events:none;
}
