/* =========================
  Zen Gothic
========================= */

body,
p,
span,
a,
li,
h1,
h2,
h3,
h4,
h5,
h6 {

  font-family:
  'Zen Kaku Gothic New',
  sans-serif !important;
  
}

/* Gナビ */

.gnav,
.gnav a,
.global-nav,
.global-nav a,
nav,
nav a {

  font-family:
  'Zen Kaku Gothic New',
  sans-serif !important;

}

/* 商品名 */

.item-name,
.product-name,
.item-title,
.product-title {

  font-family:
  'Zen Kaku Gothic New',
  sans-serif !important;

}

/* 価格 */

.price,
.item-price,
.product-price {

  font-family:
  'Zen Kaku Gothic New',
  sans-serif !important;

}

/* 商品説明 */

.item-description,
.product-description,
.description {

  font-family:
  'Zen Kaku Gothic New',
  sans-serif !important;

}





/* =============================================
   共通
============================================= */
.top-wrap { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.section-title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 3px;
  margin-bottom: 20px;
}




/* =============================================
   バナーエリア（2枚横並び）
============================================= */
.banner-2col {
  display: flex;
  gap: 4px;
  margin-bottom: 4px;
}
.banner-2col a {
  flex: 1;
  display: block;
  overflow: hidden;
}
.banner-2col img {
  width: 100%;
  height: auto;
  display: block;
  transition: opacity 0.2s;
}
.banner-2col a:hover img { opacity: 0.85; }

/* =============================================
   NEWS
============================================= */
/* INFORMATIONをバナー幅に合わせる */

.info__section {
  width: 90%;
  max-width: 1160px;
  margin: 60px auto;
  padding: 0;
}

.info__section .section__title-h2 {
  margin-bottom: 20px;
  letter-spacing: 0.12em;
}

.info__section .info {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  padding: 20px 0;
}

.info-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.info-list__unit {
  padding: 14px 0;
  border-bottom: 1px solid #eee;
  line-height: 1.9;
}

.info-list__unit:last-child {
  border-bottom: none;
}

.info-list__date {
  font-weight: bold;
  margin-right: 14px;
  white-space: nowrap;
}

/* スマホ */

@media screen and (max-width: 768px) {

  .info__section {
    width: 94%;
    margin: 40px auto;
  }

  .info-list__date {
    display: block;
    margin-bottom: 4px;
  }

}

/* =============================================
   商品グリッド（RECOMMENDED / RANKING共通）
============================================= */
.product-section { padding: 30px 0; }
.product-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
.product-card { display: block; color: #333; }
.product-card:hover .product-thumb img { opacity: 0.8; }
.product-thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  background: #f0f0f0;
  overflow: hidden;
  margin-bottom: 8px;
  position: relative;
}
.product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity 0.2s;
}
.product-name {
  font-size: 12px;
  color: #333;
  margin-bottom: 4px;
}
.product-price {
  font-size: 12px;
  color: #666;
}

/* ランキング番号バッジ */
.ranking-badge {
  position: absolute;
  top: 0;
  left: 0;
  background: #1a1a1a;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}






/* =================================
   このページだけ
   商品名・価格を中央揃え
================================= */

.item_name,
.item-name,
.product-name,
.item_price,
.price,
.item-price {

  text-align: center !important;

}

/* 商品ブロック全体 */

.item,
.product,
.item-list__item {

  text-align: center !important;

}

/* NEWアイコン位置崩れ防止 */

.itemimg,
.item-image,
.product-image {

  text-align: center;

}

.product-card{
  text-align: center;
}

.product-name{
  text-align: center;
}

.product-price{
  text-align: center;
}



/* =============================================
   特集バナー（2枚）＆ インフォバナー（4枚）
============================================= */
.feature-banners,
.info-banners {
  display: flex;
  gap: 4px;
  margin-bottom: 4px;
}
.feature-banners a,
.info-banners a {
  flex: 1;
  display: block;
  overflow: hidden;
}
.feature-banners img,
.info-banners img {
  width: 100%;
  height: auto;
  display: block;
  transition: opacity 0.2s;
}
.feature-banners a:hover img,
.info-banners a:hover img { opacity: 0.85; }
.banner-note {
  font-size: 12px;
  color: #c00;
  text-align: right;
  margin-bottom: 20px;
}

/* =============================================
   SP（スマホ）レスポンシブ
============================================= */
@media (max-width: 767px) {
  .top-wrap { padding: 0 12px; }
  .banner-2col { flex-direction: column; }
  .product-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .feature-banners { flex-direction: column; }
  .info-banners { flex-wrap: wrap; }
  .info-banners a { flex: 0 0 calc(50% - 2px); }
}
