body {
  margin: 0;
  font-family: 'Helvetica Neue', sans-serif;
  background-color: #f4f4f4;
  color: #333;
}

header {
  background-color: #4a6c6f;
  color: white;
  padding: 1em;
  text-align: center;
}

nav {
  background-color: #2f4f4f;
  padding: 0.5em;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

nav a {
  color: white;
  margin: 0 1em;
  text-decoration: none;
  padding: 0.5em 0;
}

nav a:hover {
  text-decoration: underline;
}

main {
  max-width: 900px;
  margin: auto;
  padding: 2em;
  background-color: white;
}

footer {
  text-align: center;
  padding: 1em;
  background-color: #4a6c6f;
  color: white;
  margin-top: 2em;
}


img {
  max-width: 500px;
  height: auto;
  display: block;
  margin: 1em 0;
}


iframe {
  width: 100%;
  height: 400px;
  border: 0;
  margin: 1em 0;
}

@media (max-width: 600px) {
  nav {
    flex-direction: column;
    align-items: center;
  }
}

/* ===== 3枚横並び（教会～オルガン） ===== */
.wrap-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
}
.wrap-3 img {
  width: calc((100% - 2 * 2px) / 3);
  height: auto;
}

/* ===== 4枚横並び（1～8） ===== */
.wrap-4 {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
}
.wrap-4 img {
  width: calc((100% - 3 * 2px) / 4);
  height: auto;
}

/* ===== スマホ対応 ===== */
@media (max-width: 768px) {
  /* タブレット以下は2列 */
  .wrap-3 img {
    width: calc((100% - 2px) / 2);
  }
  .wrap-4 img {
    width: calc((100% - 2px) / 2);
  }
}

@media (max-width: 480px) {
  /* スマホは1列 */
  .wrap-3 img,
  .wrap-4 img {
    width: 100%;
  }
}
