/* ===== 全体レイアウト ===== */
.container7 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 900px;
  max-width: 95%;
  margin: 0 auto;
}

/* 左側（div1）＝PC時はA＋B・C・D横並び */
.div1 {
  display: flex;
  align-items: center;   /* 高さ方向を中央揃え */
  gap: 3px;             /* 画像とボタンの間隔 */
}

/* div1内の画像とボタン */
.imgA {
  height: 20px;
  width: 100px;
}

.fntbtn-group {
  display: flex;
  gap: 5px;
}
.fntbtn {
  width: 28px;
  height: 28px;
}

/* 右側（div2） */
.div2 {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0;
  margin:0 0 1% 0;
  font-size: 0; /* ← 画像間のわずかな空白を完全除去 */
}
.div2 img {
  width: 100%;
  max-width: 120px;
  height: auto;
}

/* ===== スマホ(768px以下)では縦並びに切り替え ===== */
@media (max-width: 768px) {
  .container7 {
    flex-direction: column;
    align-items: stretch;
  }

  .div1 {
    flex-direction: column; /* Aを上、選択ボタンを下に */
    align-items: flex-start;
    margin-bottom: 10px;
  }

  .fntbtn-group {
    flex-wrap: wrap; /* 小さい画面で折返可 */
  }

  .div2 {
    justify-content: flex-end;
  }
}

/* ===== 480px以下は画像縮小して横並び維持 ===== */
@media (max-width: 480px) {
  .div2 img {
    max-width: 25%; /* 4枚横並び */
  }
}
