/* --- 基本設定 --- */
body {
  background-color: snow;
  font-family: "Zen Maru Gothic", sans-serif;
  color: #222;
  font-size: 17px;

  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  -o-appearance: none;
  -ms-appearance: none;
}

/* --- 表示幅の調整 --- */
div {
  margin: 1em auto;
}
@media screen and (orientation: portrait) {
  .description {
    width: 70vw;
  }
  .info {
    width: calc(70vw + 2em);
  }
  .map iframe {
    width: min(25em, calc(70vw - 1em));
  }
}
@media screen and (orientation: landscape) {
  .description {
    width: 65vh;
  }
  .info {
    width: calc(65vh + 2em);
  }
  .map iframe {
    width: min(25em, calc(65vh - 1em));
  }
}
@media screen and (max-width: 480px) {
  .description,
  .map {
    width: 80vw;
  }
  .info {
    width: calc(80vw + 2em);
  }
  .map iframe {
    width: min(25em, calc(80vw - 1em));
  }
}

/* --- ロゴ --- */
.logo {
  display: block;
  width: 25vh;
  height: auto;
  margin: -5vh auto 5vh;
}

/* --- 本文 --- */
p {
  text-align: center, justify;
  line-height: 1.8;
}

span {
  display: inline-block;
}

/* --- 営業時間,住所等 --- */
table {
  border-spacing: 1em 2em;
}

tr {
  position: relative;
}

td {
  vertical-align: top;
}
.caption {
  text-align: left;
  text-align-last: justify;
  white-space: nowrap;
  font-weight: bold;
}

.caption.location {
  letter-spacing: 0.1em;
}

/* --- 地図 --- */
div.map {
  margin: 0 auto 2.5em;
}

.map iframe {
  display: block;
  margin: -1em auto 0;
  aspect-ratio: 4/3;
  border: 0;
}

/*--- Instagram ---*/
div.instagram {
  margin: 1em auto 2em;
  vertical-align: middle;
  transition-duration: 0.4s;
}
@media (hover: hover) {
  div.instagram:hover {
    transform: scale(1.1);
  }
}

a {
  color: black;
  text-decoration: none;
}

img.instagram {
  margin: 0.5em 0.3em -0.3em;
  width: 2em;
  vertical-align: bottom;
}

/* --- フッター --- */
footer {
  margin: 4em -0.45em -0.5em;
  padding: 1vh 0 1em;
  background-color: blanchedalmond;
  text-align: center;
}
