@charset "UTF-8";
/* page-hero  ================================= */
.page-hero--shop {
  background-image: url(../../images/shop/hero_sp.jpg);
  background-position: 0 50%;
}

@media (min-width: 768px) {
  .page-hero--shop {
    background-image: url(../../images/shop/hero_pc.jpg);
  }
}
/* 店鋪・チラシ詳細ページ  ================================= */
.shop-section__title {
  padding-left: 2em;
  position: relative;
  margin-bottom: 0.95em;
}
.shop-section__title::before {
  content: "";
  height: 1.25em;
  position: absolute;
  top: 0;
  left: 0;
  background-repeat: no-repeat;
  background-position: 0 0;
}

.shop-flyer__title {
  padding-left: 1.45em;
}
.shop-flyer__title::before {
  width: 0.925em;
  height: 1.25em;
  background: url(../../images/shop/single/icon_title_flyer.svg) 0 0 no-repeat;
}

.shop-info__title {
  padding-left: 1.925em;
}
.shop-info__title::before {
  width: 1.4em;
  height: 1.25em;
  background: url(../../images/shop/single/icon_title_info.svg) 0 0 no-repeat;
}

.shop-services__title {
  padding-left: 1.95em;
}
.shop-services__title::before {
  width: 1.375em;
  height: 1.25em;
  background: url(../../images/shop/single/icon_title_services.svg) 0 0 no-repeat;
}

.shop-recycle__title {
  padding-left: 1.95em;
}
.shop-recycle__title::before {
  width: 1.3em;
  height: 1.25em;
  background: url(../../images/shop/single/icon_title_recycle.svg) 0 0 no-repeat;
}

.shop-payment__title {
  padding-left: 1.95em;
}
.shop-payment__title::before {
  width: 1.1em;
  height: 1.25em;
  background: url(../../images/shop/single/icon_title_payment.svg) 0 0 no-repeat;
}

/* チラシ情報 */
.shop-flyer__content {
  width: 100% !important;
  overflow-x: auto;
  overflow-y: hidden;
  background: var(--color-ffffff);
}

.shop-info__body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.shop-info__image > img {
  aspect-ratio: 6/5;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  max-height: 100%;
}

.shop-info__item {
  font-size: var(--fontsize-14);
  padding: 1.42em 0;
}

.l-dl-item {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.has-dotted-line {
  position: relative;
}
.has-dotted-line::after {
  content: "";
  width: 100%;
  height: 1px;
  background-image: var(--decoration-dotted-line);
  background-size: auto 1px;
  background-repeat: repeat-x;
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
}

.shop-info__item--cta {
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .shop-info__body {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }
  .shop-info__item {
    font-size: var(--fontsize-18);
  }
  .l-dl-item {
    grid-template-columns: 140px 1fr;
  }
}
/* 地図 */
.shop-map {
  padding-top: 0;
}

.shop-map__frame {
  height: 235px;
  position: relative;
}
.shop-map__frame > iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

@media (min-width: 768px) {
  .shop-map__frame {
    height: 460px;
  }
}
/* 設備・サービス */
.shop-services-inner {
  background-color: var(--color-ffffff);
  border-radius: 16px;
  padding: 20px;
}

.shop-services__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
}

.shop-services__icon {
  display: block;
  width: 100%;
  max-width: 120px;
  aspect-ratio: 1/1;
  margin-bottom: 8px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* サービス別 */
.shop-services__item--color_copy .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_color_copy.svg");
}

.shop-services__item--parcel_locker .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_parcel_locker.svg");
}

.shop-services__item--photo_booth .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_photo_booth.svg");
}

.shop-services__item--water_refill .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_water_refill.svg");
}

.shop-services__item--rest_area .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_rest_area.svg");
}

.shop-services__item--wheelchair_rental .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_wheelchair_rental.svg");
}

.shop-services__item--priority_parking .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_priority_parking.svg");
}

.shop-services__item--accessible_toilet .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_accessible_toilet.svg");
}

.shop-services__item--aed .shop-services__icon {
  background-image: url("../../images/shop/single/icon_services_aed.svg");
}

.shop-services__text {
  font-size: var(--fontsize-12);
  line-height: 1.2;
  text-align: center;
  display: block;
}

@media (min-width: 768px) {
  .shop-services-inner {
    padding: 40px;
  }
  .shop-services__list {
    grid-template-columns: repeat(6, minmax(0, 120px));
    gap: 5%;
  }
  .shop-services__text {
    font-size: var(--fontsize-16);
  }
}
/* リサイクル */
.shop-recycle-inner {
  background-color: var(--color-ffffff);
  border-radius: 16px;
  padding: 20px;
}

.shop-recycle__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
}

.shop-recycle__icon {
  display: block;
  width: 100%;
  max-width: 120px;
  aspect-ratio: 1/1;
  margin-bottom: 8px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* リサイクル別 */
.shop-recycle__item--milk_carton .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_milk_carton.svg");
}

.shop-recycle__item--food_tray .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_food_tray.svg");
}

.shop-recycle__item--can .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_can.svg");
}

.shop-recycle__item--pet_bottle_cap .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_pet_bottle_cap.svg");
}

.shop-recycle__item--waste_paper .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_waste_paper.svg");
}

.shop-recycle__item--used_cooking_oil .shop-recycle__icon {
  background-image: url("../../images/shop/single/icon_recycle_used_cooking_oil.svg");
}

.shop-recycle__text {
  font-size: var(--fontsize-12);
  line-height: 1.2;
  text-align: center;
  display: block;
}

@media (min-width: 768px) {
  .shop-recycle-inner {
    padding: 40px;
  }
  .shop-recycle__list {
    grid-template-columns: repeat(6, minmax(0, 120px));
    gap: 5%;
  }
  .shop-recycle__text {
    font-size: var(--fontsize-16);
  }
}
/* 支払い方法 */
.shop-payment__group {
  margin: 40px 0;
}

.shop-payment__names-outer {
  background-color: #f5f4f4;
  padding: 1em;
  border-radius: 10px;
}

.shop-payment__names {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.shop-payment__names-item {
  position: relative;
  padding-right: 1.5em;
}

.has-slash {
  position: relative;
}

.has-slash::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 1px;
  width: 1.2em;
  height: 1px;
  background-color: var(--color-69472f);
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
}

.has-slash:last-child::before {
  content: none;
}

.shop-payment__icons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 20px;
}

/* クレジットカード */
.shop-payment__icons.shop-payment__icons--card .shop-payment__icon {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 93px;
          flex: 0 0 93px;
  width: 93px;
  height: 50px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.shop-payment__icon--visa {
  background-image: url(../../images/shop/single/icon_payment_visa.png);
}

.shop-payment__icon--mastercard {
  background-image: url(../../images/shop/single/icon_payment_mastercard.png);
}

.shop-payment__icon--jcb {
  background-image: url(../../images/shop/single/icon_payment_jcb.png);
}

.shop-payment__icon--uc {
  background-image: url(../../images/shop/single/icon_payment_uc.png);
}

.shop-payment__icon--amex {
  background-image: url(../../images/shop/single/icon_payment_amex.png);
}

.shop-payment__icon--diners {
  background-image: url(../../images/shop/single/icon_payment_diners.png);
}

/* QR */
.shop-payment__icons.shop-payment__icons--qr {
  gap: 10px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.shop-payment__icons.shop-payment__icons--qr .shop-payment__icon {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 auto;
          flex: 0 1 auto;
  width: auto;
  -ms-flex-item-align: baseline;
      align-self: baseline;
}

@media (max-width: 575.98px) {
  .shop-payment__icons {
    gap: 5px;
  }
  .shop-payment__icon--visa {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 60px !important;
            flex: 0 0 60px !important;
    width: 60px !important;
  }
  .shop-payment__icon--mastercard {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 54px !important;
            flex: 0 0 54px !important;
    width: 54px !important;
  }
  .shop-payment__icon--jcb {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 48px !important;
            flex: 0 0 48px !important;
    width: 48px !important;
  }
  .shop-payment__icon--uc {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 42px !important;
            flex: 0 0 42px !important;
    width: 42px !important;
  }
  .shop-payment__icon--amex {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 42px !important;
            flex: 0 0 42px !important;
    width: 42px !important;
  }
  .shop-payment__icon--diners {
    -webkit-box-flex: 0 !important;
        -ms-flex: 0 0 45px !important;
            flex: 0 0 45px !important;
    width: 45px !important;
  }
  .shop-payment__icon--paypay {
    width: 77px !important;
  }
  .shop-payment__icon--rakuten_pay {
    width: 46px !important;
  }
  .shop-payment__icon--d_pay {
    width: 50px !important;
  }
  .shop-payment__icon--au_pay {
    width: 47px !important;
  }
  .shop-payment__icon--merpay {
    width: 55px !important;
  }
  .shop-payment__icon--j_coin_pay {
    width: 68px !important;
  }
  .shop-payment__icon--wechat {
    width: 80px !important;
  }
  .shop-payment__icon--yucho {
    width: 123px !important;
  }
}
/* 店鋪・チラシ一覧ページ  ================================= */
.shop-archive-nav__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

/* 地図画像 */
#area-map {
  width: 100%;
  max-width: 493px;
  height: auto;
  display: block;
  margin: 0 auto;
}

#area-map a:hover path {
  opacity: 0.5;
  cursor: pointer;
}

#area-map a {
  pointer-events: all;
}

#area-map path {
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}

.shop-archive-nav__title {
  font-size: clamp(1.5rem, 0.167rem + 2.78vw, 2.25rem);
  margin-bottom: 2em;
}

.shop-archive-nav__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
}

.shop-archive-nav__link {
  color: currentColor;
  font-size: clamp(1.125rem, 0.014rem + 2.31vw, 1.75rem);
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  background-color: var(--color-ffffff);
  border: 1px solid var(--color-69472f);
  border-radius: 10px;
  padding: 0.3em;
  display: block;
}
.shop-archive-nav__link:hover {
  color: var(--color-ffffff);
  background-color: var(--color-69472f);
}

.has-arrow-down {
  position: relative;
  padding-right: 2em;
}

.has-arrow-down::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.shop-archive-area-nav {
  margin-bottom: 30px;
}

.shop-archive-area-nav__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, -webkit-max-content));
  grid-template-columns: repeat(auto-fill, minmax(100px, max-content));
  gap: 10px;
}

.shop-archive-area-nav__link {
  color: var(--color-ffffff);
  text-decoration: none;
  text-align: center;
  background-color: var(--color-c3a58c);
  border-radius: 10px;
  display: block;
  position: relative;
  padding: 0.5em;
  padding-right: 1.5em;
}
.shop-archive-area-nav__link::after {
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.shop-archive-area-nav__link:hover {
  color: var(--color-ffffff);
  opacity: 0.5;
}

.shop-city {
  background-color: var(--color-f9f6f1);
  border-radius: 10px;
  margin-bottom: 25px;
}

.shop-city__title {
  width: 100%;
}

.shop-city__toggle {
  width: 100%;
  height: 70px;
  font-size: clamp(1.125rem, 0.014rem + 2.31vw, 1.75rem);
  color: var(--color-69472f);
  font-weight: 600;
  text-align: left;
  border: 1px solid var(--color-c3a58c);
  border-radius: 10px;
  background-color: var(--color-ffffff);
  padding: 0.5em 1.7857em;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

.shop-city__toggle {
  position: relative;
  padding-right: 50px; /* アイコン分の余白 */
}

/* 共通設定 */
.shop-city__toggle::after,
.shop-city__toggle::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 25px;
  height: 2px;
  background-color: var(--color-ff8200);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transition: transform 0.3s ease, opacity 0.3s ease, -webkit-transform 0.3s ease;
}

/* 縦棒（＋の縦線） */
.shop-city__toggle::before {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}

/* 開いている状態（−） */
.shop-city__toggle[aria-expanded=true]::before {
  opacity: 0; /* 縦棒を消す */
}

.shop-city__content {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  -webkit-transition: max-height 0.4s ease, opacity 0.3s ease;
  transition: max-height 0.4s ease, opacity 0.3s ease;
}

.shop-city__content.is-open {
  max-height: 2000px;
  opacity: 1;
  padding-bottom: 1rem;
}

.shop-list__item {
  background-color: var(--color-ffffff);
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 1rem;
  padding: 10px;
}

.shop-list__name {
  margin-bottom: 0;
}

.shop-list__name-link {
  color: var(--color-e60012);
  font-size: clamp(1.125rem, 0.014rem + 2.31vw, 1.75rem);
  font-weight: 600;
}
.shop-list__name-link:hover {
  color: var(--color-e60012);
  opacity: 0.5;
}

.shop-list__meta {
  font-size: var(--fontsize-14);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.shop-list__meta > p {
  margin-bottom: 0;
}

.shop-list__hours {
  padding-left: 30px;
  position: relative;
}
.shop-list__hours::before {
  content: "";
  width: 20px;
  height: 20px;
  background: url(../../images/shop/archive/icon_shop_list_hours.svg) 0 0 no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  bottom: 0;
  display: inline-block;
}

.shop-list__tel {
  padding-left: 30px;
  position: relative;
}
.shop-list__tel::before {
  content: "";
  width: 20px;
  height: 20px;
  background: url(../../images/shop/archive/icon_shop_list_tel.svg) 0 0 no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  bottom: 0;
  display: inline-block;
}

.shop-list__actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.shop-list__action,
.simplefavorite-button {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.shop-list__action--flyer {
  width: 100%;
  max-width: 150px;
  height: 30px;
  font-size: var(--fontsize-12);
  text-decoration: none;
  color: var(--color-ffffff);
  border-radius: 15px;
  background-color: var(--color-e60012);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  position: relative;
}
.shop-list__action--flyer::before {
  content: "";
  width: 13px;
  height: 18px;
  background: url(../../images/shop/archive/icon_shop_list_action_flyer.svg) 0 0 no-repeat;
  display: inline-block;
}
.shop-list__action--flyer:hover {
  color: var(--color-ffffff);
  opacity: 0.5;
}

.simplefavorite-button {
  width: 100%;
  max-width: 150px;
  height: 30px;
  font-size: var(--fontsize-12);
  border-radius: 15px;
  border: none;
  border: 1px solid #e5696b;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  position: relative;
}
.simplefavorite-button::before {
  content: "";
  width: 16px;
  height: 13px;
  background: url(../../images/shop/archive/icon_shop_list_action_favorites.svg) 0 0 no-repeat;
  display: inline-block;
}
.simplefavorite-button:hover {
  opacity: 0.5;
}

.simplefavorite-button.active::before {
  content: "";
  width: 16px;
  height: 13px;
  background: url(../../images/shop/archive/icon_shop_list_action_favorites_active.svg) 0 0 no-repeat;
  display: inline-block;
}

.shop-list__action--line:hover {
  opacity: 0.5;
}

@media (min-width: 768px) {
  .shop-archive-nav__content {
    grid-template-columns: 1fr 1fr;
  }
  .shop-archive-nav__list {
    gap: 40px;
  }
  .shop-archive-area-nav__list {
    grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  }
  .shop-list__item {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 992px) {
  .shop-list__item {
    grid-template-columns: 200px 1fr 1fr;
    gap: 20px;
    padding: 30px;
  }
}/*# sourceMappingURL=shop.css.map */