/* ===== カルーセルを独立した表示領域に ===== */
.carousel {
  position: relative;
  width: 100%;
  max-width: 980px;        /* ← ベース幅に合わせる */
  margin: 0 auto;          /* ← 中央揃え */
  overflow: hidden;        /* ← はみ出し防止 */
}

/* ===== 横スクロール本体 ===== */
.carousel .product6-list {
  display: flex;
  flex-wrap: nowrap !important;   /* ← ベース干渉を遮断 */
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;

  gap: 12px;
  padding: 12px 44px;
  box-sizing: border-box;

  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
}

/* スクロールバー非表示 */
.carousel .product6-list::-webkit-scrollbar {
  display: none;
}

/* ===== 商品カード ===== */
.carousel .product6 {
  flex: 0 0 160px;         /* ← 幅固定 */
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 10px;
  padding: 8px;
  box-sizing: border-box;

  scroll-snap-align: start;
  transition: transform .2s ease, box-shadow .2s ease;
}

.carousel .product6:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}

@media (min-width: 768px) {
  .carousel .product6 {
    flex-basis: 190px;
  }
}

/* ===== 矢印 ===== */
.carousel .nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  line-height: 38px;
  font-size: 22px;
  text-align: center;
  border-radius: 50%;
  text-decoration: none;

  background: rgba(0,0,0,.55);
  color: #fff;
  z-index: 5;

  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
}

.carousel .prev { left: 6px; }
.carousel .next { right: 6px; }

/* PCホバー時のみ表示 */
@media (hover:hover) and (pointer:fine) {
  .carousel:hover .nav {
    opacity: 1;
    pointer-events: auto;
  }
}

/* スマホ非表示 */
@media (hover:none) {
  .carousel .nav { display: none; }
}
