@charset "utf-8";

/* グリッド：PC 2列 / SP 1列 */
.banner-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 16px;
  box-sizing: border-box;
}

/* カード（角丸＋柔らかい影） */
.banner-item {
  display: block;
  background: #fff;
  /* ← 画像端の白縁対策にも効く */
  border-radius: 16px;
  overflow: hidden;
  /* 角丸を画像に反映 */
  box-shadow:
    0 12px 28px rgba(17, 24, 28, .12),
    /* ふんわり外側 */
    0 4px 10px rgba(17, 24, 28, .06);
  /* 足元を締める */
  transition: transform .25s ease, box-shadow .25s ease;
  will-change: transform;
}

/* 画像は面で見せる */
.banner-item img {
  display: block;
  width: 100%;
  height: auto;
  /* aspect-ratio: 3 / 1; */
  /* 任意：統一したいなら */
  object-fit: contain;
  /* はみ出し気味でも面が綺麗に見える */
}

/* PCホバー：控えめに浮かせる（スマホは無効） */
@media (hover:hover) {
  .banner-item:hover {
    transform: translateY(-3px);
    box-shadow:
      0 16px 36px rgba(17, 24, 28, .16),
      0 6px 14px rgba(17, 24, 28, .08);
  }
}

/* SPは1列に */
@media (max-width: 768px) {
  .banner-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}