/* フォトギャラリー全体 */
#fotos {
  padding: 20px;
}

/* グリッドコンテナ */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); /* 3列表示 */
  grid-gap: 10px;
}

/* 各写真のサムネイル */
.gallery-item {
  display: block; /* 画像をブロック要素にする */
  border: 1px solid #ccc; /* 枠線を追加 */
  border-radius: 10px;  /* 角丸を追加 */
  overflow: hidden; /* 角丸を維持するために overflow: hidden を追加 */
  box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);
  cursor: pointer;
}

.gallery-item img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3; /* 4:3のアスペクト比を維持 */
  object-fit: cover; /* 画像をトリミング */
}

/* モーダルウィンドウ */
.gallery-modal {
  display: none;
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.8);
}

.gallery-modal .modal-content {
  position: relative;
  margin: 5% auto;
  padding: 20px;
  max-width: 90%; /* スマートフォンでは画面幅いっぱいに */
  background-color: #fff;
}

.gallery-modal .modal-content img {
  width: 100%;
  height: auto;
}

.gallery-modal .close {
  position: absolute;
  top: 10px;
  right: 15px;
  font-size: 20px;
  color: #fff;
  cursor: pointer
}