@charset "UTF-8";
/*
#overview
base
*/
/*
#colors
@$primaryColor #5a8c3c
@$secondaryColor #ef8f3a
@$textColor #2b2922
*/
.shop {
  padding-top: 58px;
}

.category {
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 640px) {
  .category {
    gap: 20px;
  }
}
@media screen and (max-width: 640px) {
  .category {
    flex-direction: column;
  }
}
.category .m-btn-center {
  padding-top: 59px;
}
@media screen and (max-width: 640px) {
  .category .m-btn-center {
    padding-top: 30px;
  }
}
.category-list {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.category-list-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px;
}
@media screen and (max-width: 640px) {
  .category-list-item {
    flex-direction: column;
    justify-content: center;
  }
}
.category-list-item:hover {
  text-decoration: none;
}
.category-list-item:hover .category-list__title::after {
  margin-left: 8px;
}
.category-list__image {
  width: 94px;
  height: 94px;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  background-color: #ccc;
}
.category-list__image img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}
.category-list__title {
  font-size: 13px;
  font-size: calc(13 / 16)rem;
  letter-spacing: 0.035em;
  line-height: calc(41.82 / 30);
  background-color: #eff7f6;
  padding-bottom: 6px;
  padding: 5px 25px;
  border-radius: 15px;
  position: relative;
}
@media screen and (max-width: 640px) {
  .category-list__title {
    font-size: 12px;
    font-size: calc(12 / 16)rem;
    max-width: none;
  }
}

.all {
  padding-top: 87px;
}
.all-ttl {
  font-size: 20px;
  font-size: calc(20 / 16)rem;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.115em;
}
.all-list {
  display: flex;
  flex-wrap: wrap;
  gap: 28px 23px;
  padding-top: 64px;
}
.all-list-item {
  width: min(257px, 25% - 18px);
}
@media screen and (max-width: 640px) {
  .all-list-item {
    width: calc(50% - 12px);
  }
}
.all-list-item:hover {
  text-decoration: none;
}
.all-list-item:hover .all-list__image img {
  opacity: unset;
  transform: scale(1.05);
}
.all-list__image {
  aspect-ratio: 515/357;
  overflow: hidden;
  border-radius: 10px;
}
.all-list__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.2s;
  border-radius: 10px;
}
.all-list__shopname {
  font-size: 14px;
  font-size: calc(14 / 16)rem;
  letter-spacing: 0.035em;
  padding-top: 15px;
}
.all-list__caption {
  font-size: 13px;
  font-size: calc(13 / 16)rem;
  line-height: calc(43 / 26);
  letter-spacing: 0.035em;
  padding-top: 3px;
}
.all-list h3 {
  border-bottom: 1px solid #646464;
}
.all-list__shop-number {
  font-size: 13px;
  font-size: calc(13 / 16)rem;
  line-height: 1.25em;
}

.shop-post {
  width: min(767px, 100%);
  margin-inline: auto;
  padding-top: 83px;
}
@media screen and (max-width: 640px) {
  .shop-post {
    padding-top: 50px;
  }
}
.shop-post-info {
  padding: 30px 11px 0;
}
.shop-post-info p {
  padding: 0;
}
.shop-post-info-wrap {
  display: flex;
  margin-bottom: 1em;
}
.shop-post-info-wrap h3 {
  width: 6em;
  font-size: 15px;
  font-size: calc(15 / 16)rem;
}
.shop-post-gallery {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 33px;
  padding: 35px 0 0;
}
@media screen and (max-width: 640px) {
  .shop-post-gallery {
    gap: 20px;
  }
}
.shop-post-gallery-item {
  width: min(232px, 33.333% - 22px);
  aspect-ratio: 1;
  position: relative;
}
@media screen and (max-width: 640px) {
  .shop-post-gallery-item {
    width: calc(50% - 10px);
  }
}
.shop-post-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  border: none;
  clip-path: polygon(17px 0%, calc(100% - 17px) 0%, 100% 17px, 100% calc(100% - 17px), calc(100% - 17px) 100%, 17px 100%, 0% calc(100% - 17px), 0% 17px);
}
.shop-post-gallery-item__caption {
  font-size: 13px;
  font-size: calc(13 / 16)rem;
  width: 100%;
  padding: 10px !important;
  border-radius: 0;
  word-break: break-word;
}
.shop-post-gallery-item:hover .shop-post-gallery-item__caption {
  display: block;
}
.shop-post .m-post-heading {
  border-bottom: none;
  flex-direction: column;
}
.shop-post .m-post-heading__title {
  flex-direction: column;
  align-items: center;
}
.shop-post .m-post-heading__title h2 {
  font-size: 25px;
  font-size: calc(25 / 16)rem;
  font-weight: 500;
  letter-spacing: 0.155em;
  margin-bottom: 0.5em;
}
.shop-post .m-post-heading__title .area {
  font-size: 15px;
  font-size: calc(15 / 16)rem;
  border-radius: 12px;
  border: solid 1px #646464;
  padding: 0 5px;
  margin-bottom: 10px;
}

.shop-interview {
  width: min(767px, 100%);
  margin-inline: auto;
  margin-top: 40px;
}
@media screen and (max-width: 640px) {
  .shop-interview {
    margin-top: 30px;
  }
}
.shop-interview__body {
  background: #fff;
  padding: 24px;
}
@media screen and (max-width: 640px) {
  .shop-interview__body {
    padding: 16px;
  }
}

.shop-thumbnail {
  position: relative;
  display: inline-block;
  width: 100%;
  padding: 30px 13px 0;
}

.shop-thumbnail img {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  border-radius: 25px;
  border: 1px solid #646464;
}

.thumbnail-border {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  clip-path: polygon(8px 0%, calc(100% - 8px) 0%, 100% 8px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0% calc(100% - 8px), 0% 8px);
  border: 1px solid #a5a383; /* 画像の周囲にある枠線の色を指定 */
  pointer-events: none; /* 枠線がクリックできないようにする */
  box-sizing: border-box;
}

/*# sourceMappingURL=shop.css.map */
