#top h1 {
  width: 70%;
  margin: 0 auto 40px;
  text-align: center;
}
@media screen and (max-width: 520px) {
  #top h1 {
    margin: 0 auto 30px;
  }
}
#top h2 {
  font-size: 30px;
  margin-bottom: 20px;
}
@media screen and (max-width: 1024px) {
  #top h2 {
    font-size: 5vmin;
  }
}
@media screen and (max-width: 520px) {
  #top h2 {
    font-size: 24px;
    line-height: 1.4;
    margin-bottom: 15px;
  }
}
#top h2 span {
  display: block;
  font-size: 22px;
}
@media screen and (max-width: 520px) {
  #top h2 span {
    font-size: 16px;
    margin-bottom: 5px;
  }
}
#top .center {
  text-align: center;
}
#top .center p {
  line-height: 2.3;
}
@media screen and (max-width: 768px) {
  #top .center p {
    text-align: left;
    line-height: 1.8;
    letter-spacing: 0.02rem;
  }
}
#top .flex {
  display: flex;
}
#top .w_bg {
  padding: 40px;
  background-color: #fff;
}
@media print {
  #top .w_bg {
    padding: 30px;
  }
}
@media screen and (max-width: 1024px) {
  #top .w_bg {
    padding: 40px;
  }
}
@media screen and (max-width: 768px) {
  #top .w_bg {
    padding: 30px;
  }
}
@media screen and (max-width: 520px) {
  #top .w_bg {
    padding: 25px;
  }
}
#top section {
  padding-bottom: 90px;
}
@media screen and (max-width: 520px) {
  #top section {
    padding-bottom: 45px;
  }
}
#top #section20 p {
  margin-bottom: 20px;
}
#top #section20 .button01 {
  margin: 30px auto 0;
}
#top #flyer .button01 {
  margin: 30px auto 0;
}
#top #flyer .button01::after {
  background-image: url(../images/top/download1@2x.png);
}
#top #flyer .button01:hover::after {
  background-image: url(../images/top/download2@2x.png);
}
#top #flyer .flyer-wrap + .flyer-wrap {
  margin-top: 60px;
}
#top #contact {
  text-align: center;
}
#top #contact .ttl {
  font-size: 20px;
  margin-bottom: 10px;
}
#top .wrapper {
  margin: 0 auto;
  max-width: 1000px;
  width: 90%;
}
#top .openTime {
  font-size: 18px;
  font-weight: bold;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 1024px) {
  #top .openTime {
    flex-direction: column;
  }
}
@media screen and (max-width: 520px) {
  #top .openTime {
    font-size: 16px;
  }
}
#top .openTime p {
  margin: 0 20px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #top .openTime p {
    margin: 0 10px;
  }
}
@media screen and (max-width: 520px) {
  #top .openTime p .yaki {
    text-indent: -3.5em;
    padding-left: 3.5em;
  }
}
#top #instagram .insta_list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 20px 0;
}
#top #instagram .insta_list li {
  position: relative;
  width: calc((100% - 40px) / 4);
}
@media screen and (max-width: 480px) {
  #top #instagram .insta_list li {
    width: calc((100% - 10px) / 2);
  }
}
#top #instagram .insta_list li::before {
  content: "";
  display: block;
  padding-top: 100%;
}
#top #instagram .insta_list a {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
#top #instagram .insta_list img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#top #instagram .button01 {
  margin: 35px auto 0;
}
#top .flyerArea {
  justify-content: space-between;
}
@media screen and (max-width: 520px) {
  #top .flyerArea {
    flex-direction: column;
  }
}
#top .flyerArea img {
  width: 48%;
}
@media screen and (max-width: 520px) {
  #top .flyerArea img {
    width: 100%;
  }
  #top .flyerArea img + img {
    margin-top: 20px;
  }
}
