@charset "UTF-8";
.home h2 {
  margin-bottom: 50px;
  font-size: 36px;
  text-align: center;
  font-family: Cardo, sans-serif;
  letter-spacing: 5px;
}
.concept {
  margin: 0 auto 150px;
  padding: 50px 0 0;
  text-align: center;
}
.concept strong {
  display: block;
  font-family: Cardo, sans-serif;
  font-size: 36px;
  letter-spacing: 2px;
  margin-bottom: 100px;
}
.concept img {
  width: 210px;
  height: auto;
  margin-bottom: 60px;
}
.concept p {
  font-family: Noto Sans JP, serif;
  font-weight: 100;
  font-size: 22px;
  line-height: 2.6;
}
.more {
  text-align: right;
  font-family: Rokkitt, serif;
}
.more a {
  font-size: 20px;
  color: #000;
}
.top_insta {
  margin-bottom: 30px;
}
.top_insta a {
  position: relative;
  display: block;
  width: 450px;
  margin: 0 auto;
  font-size: 30px;
  font-family: Rokkitt, serif;
  line-height: 2.4;
  background: #f0eee9;
  color: #000;
  border-radius: 36px;
}
.top_insta a:after {
  position: absolute;
  top: 2px;
  right: 30px;
  content: "⟩⟩";
}
.top_insta a span {
  margin-right: 20px;
  letter-spacing: 4px;
}
.top_insta a img {
  width: 30px;
  height: auto;
  margin-right: 20px;
  margin-bottom: 5px;
  vertical-align: middle;
}
.top_onlinestore {
  margin-bottom: 150px;
}
.top_onlinestore a {
  position: relative;
  display: block;
  width: 450px;
  margin: 0 auto;
  font-size: 30px;
  font-family: Rokkitt, serif;
  line-height: 2.4;
  background: #f0eee9;
  color: #000;
  border-radius: 36px;
}
.top_onlinestore a:after {
  position: absolute;
  top: 2px;
  right: 30px;
  content: "⟩⟩";
}
.top_onlinestore a span {
  letter-spacing: 4px;
}
.top_news {
  margin-bottom: 150px;
}
.top_news .news_post {
  display: flex;
  align-items: center;
  width: 720px;
  margin: 0 auto 35px;
}
.top_news .news_post a {
  margin-right: 20px;
}
.top_news .news_post a img {
  width: 150px;
  height: 150px;
}
.top_news .news_post .news_post_meta {
  width: 100%;
}
.top_news .news_post time {
  display: block;
  padding-bottom: 15px;
  font-size: 16px;
}
.top_news .news_post p {
  font-size: 16px;
  font-weight: 300;
}
.top_news .news_post p a {
  color: #000;
}
.top_news .news_post:last-of-type {
  margin-bottom: 30px;
}
.top_shop_list {
  margin-bottom: 225px;
}
.top_shop_list ul {
  display: flex;
  width: 950px;
  margin: 0 auto;
  flex-wrap: wrap;
}
.top_shop_list ul li {
  position: relative;
  width: 23%;
  margin-right: calc(8% / 3);
  margin-bottom: 35px;
  border-bottom: 1px solid #000;
  text-align: center;
  list-style-type: none;
  font-size: 18px;
}
.top_shop_list ul li:nth-child(4n) {
  margin-right: 0;
}
.top_shop_list ul li:after {
  content: "⟩⟩";
  position: absolute;
  right: 15px;
  bottom: 1px;
}
.top_shop_list ul li a {
  display: inline-block;
  color: #000;
}
@media screen and (max-width: 1180px) {
  body {
    margin: 0;
  }
  .top_shop_list ul {
    width: 87%;
  }
  .top_shop_list ul li:after {
    right: 5px;
  }
}
@media screen and (max-width: 1080px) {
  body {
    margin: 0;
  }
}
@media screen and (max-width: 768px) {
  body {
    margin: 0;
  }
  .home h2 {
    margin-bottom: 35px;
    font-size: 20px;
    letter-spacing: 4px;
  }
  .concept {
    width: 90%;
    margin: 50px auto;
    padding: 35px 0;
  }
  .concept strong {
    margin-bottom: 40px;
    font-size: 20px;
    letter-spacing: 1px;
    font-variant-ligatures: none;
    line-height: 1.1;
  }
  .concept img {
    width: 33%;
  }
  .concept p {
    font-size: 14px;
  }
  .more {
    padding-right: 10px;
    text-align: right;
  }
  .more a {
    font-size: 16px;
  }
  .top_insta a {
    line-height: 2;
    width: 60%;
    font-size: 16px;
    padding-top: 3px;
  }
  .top_insta a span {
    letter-spacing: 2.5px;
  }
  .top_insta a img {
    width: 20px;
    height: auto;
    margin-bottom: 8px;
    margin-right: 15px;
    vertical-align: bottom;
  }
  .top_onlinestore a {
    width: 60%;
    height: 35px;
    font-size: 16px;
    line-height: 35px;
  }
  .top_onlinestore a span {
    letter-spacing: 2.5px;
  }
  .top_onlinestore {
    margin-bottom: 100px;
  }
  .top_news {
    margin-bottom: 100px;
  }
  .top_news .news_post {
    width: 87%;
    margin-bottom: 0;
    padding: 15px 0;
    align-items: flex-start;
  }
  .top_news .news_post a {
    margin-right: 15px;
  }
  .top_news .news_post a img {
    width: 100px;
    height: 100px;
  }
  .top_news .news_post time {
    padding-bottom: 5px;
    font-size: 12px;
  }
  .top_news .news_post p {
    padding-top: 5px;
    font-size: 12px;
  }
  .top_news .news_post:last-of-type {
    margin-bottom: 0;
  }
  .top_shop_list {
    margin-bottom: 150px;
  }
  .top_shop_list ul {
    width: 87%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
  .top_shop_list ul li {
    width: 47%;
    font-size: 14px;
    margin-bottom: 20px;
    margin-right: 0;
  }
}
