/*!
global > color
------------------------------
*/
/*!
global > content-width
------------------------------
*/
/*!
global > font
------------------------------
*/
/*!
global > mixin
------------------------------
*/
.c-maparea__table .c-area01 {
  font-size: 0.875rem;
}
@media screen and (min-width: 768px) {
  .c-maparea__table .c-area01 {
    font-size: clamp(0.875rem, 0.2976190476vw + 0.7321428571rem, 1rem);
  }
}

.c-lead01 {
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .c-lead01 {
    font-size: clamp(1rem, 0.2976190476vw + 0.8571428571rem, 1.125rem);
  }
}

.p-shop .mv-ttl {
  font-size: clamp(1.4375rem, 0.2544529262vw + 1.3778625954rem, 1.5rem);
}
@media screen and (min-width: 768px) {
  .p-shop .mv-ttl {
    font-size: clamp(1.5rem, 2.380952381vw + 0.3571428571rem, 2.5rem);
  }
}

.p-shop .mv {
  position: relative;
  background-color: #FEF6EA;
  min-height: 350px;
  padding-top: 100px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .p-shop .mv {
    min-height: 390px;
    padding-top: 143px;
  }
}
.p-shop .mv-inner {
  position: relative;
  z-index: 1;
}
.p-shop .mv-ttl {
  line-height: 1.2;
  font-weight: 700;
  margin-top: 57px;
  text-shadow: 0px 0px 16px #fff, 1px 1px 16px #fff, 2px 2px 16px #fff, 3px 3px 16px #fff;
  -webkit-text-stroke: 2px #fff;
  paint-order: stroke fill;
}
.p-shop .mv-ttl--primary {
  color: #F76700;
}
.p-shop .mv::after {
  content: "";
  display: block;
  width: 100%;
  height: 30px;
  position: absolute;
  top: 100%;
  left: 50%;
  translate: -50% 0;
  background: url(../../assets/images/main_mv_bg_bottom01.webp) center/cover no-repeat;
}
@media screen and (min-width: 768px) {
  .p-shop .mv::after {
    height: 50px;
  }
}
.p-shop .sec02 {
  background-color: #fff;
  padding: 60px 0;
}
@media screen and (min-width: 768px) {
  .p-shop .sec02 {
    padding: 105px 0 127px;
  }
}
.p-shop .sec02-desc01 {
  line-height: 1.53;
}
.p-shop .sec02 .scrollable {
  overflow: hidden;
}
.p-shop .sec02 .scrollable .scroll-hint-icon-wrap {
  z-index: 2;
}
.p-shop .sec02 .c-maparea {
  min-width: 767px;
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .p-shop .sec02 .c-maparea {
    min-height: 360px;
    width: 100%;
    max-width: 837px;
    min-width: 767px;
    margin-inline: auto;
    margin-top: 71px;
  }
}
.p-shop .sec02 .list {
  max-width: 816px;
  margin-inline: auto;
  margin-top: 39px;
}
.p-shop .sec02 .list .item-heading {
  border-bottom: 1px dashed #5C4D2C;
  position: relative;
  cursor: pointer;
}
.p-shop .sec02 .list .item-heading__ttl {
  padding: 16px 45px 15px 8px;
}
.p-shop .sec02 .list .item-heading::after {
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 24/15;
  background: url(../images/common_icon_arrowbottom01.svg) center/cover no-repeat;
  position: absolute;
  top: calc(50% + 2px);
  right: 14px;
  translate: 0 -50%;
  -webkit-transition: 0.5s all ease-in-out;
  transition: 0.5s all ease-in-out;
}
@media screen and (min-width: 768px) {
  .p-shop .sec02 .list .item-heading::after {
    width: 24px;
    right: 16px;
  }
}
.p-shop .sec02 .list .item-content {
  display: none;
}
.p-shop .sec02 .list .item.active .item-heading::after {
  rotate: 180deg;
}
.p-shop .sec03 {
  position: relative;
  z-index: 2;
  padding: 60px 0;
}
@media screen and (min-width: 768px) {
  .p-shop .sec03 {
    padding: 53px 0 83px;
  }
}
.p-shop .sec03::before {
  content: "";
  display: block;
  width: 100%;
  height: 30px;
  position: absolute;
  bottom: 100%;
  left: 50%;
  translate: -50% 0;
  background: url(../../assets/images/common_bg_top.webp) center/cover no-repeat;
  rotate: 180deg;
}
@media screen and (min-width: 768px) {
  .p-shop .sec03::before {
    height: 50px;
  }
}
.p-shop .sec03::after {
  content: "";
  display: block;
  width: 100%;
  height: 30px;
  position: absolute;
  top: 100%;
  left: 50%;
  translate: -50% 0;
  background: url(../../assets/images/common_bg_bottom.webp) center/cover no-repeat;
}
@media screen and (min-width: 768px) {
  .p-shop .sec03::after {
    height: 50px;
  }
}
.p-shop .sec03-faq {
  max-width: 816px;
  width: 100%;
  margin-inline: auto;
  margin-top: 40px;
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .p-shop .sec03-faq {
    margin-top: 55px;
  }
}
.p-shop .sec04 {
  background-color: #FFFFFF;
  padding: 60px 0;
}
@media screen and (min-width: 768px) {
  .p-shop .sec04 {
    padding: 122px 0 108px;
  }
}
.p-shop .sec04 .c-heading01__txt {
  text-shadow: 0 0 7px rgba(255, 255, 255, 0.25);
}
.p-shop .sec04 .c-contactbox01 {
  margin-top: 55px;
}
.p-shop .sec04 .c-btn01 {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .p-shop .sec04 .c-btn01 {
    margin-top: 41px;
  }
}

.c-maparea {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  z-index: 1;
}
.c-maparea__group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 16px;
}
.c-maparea__group .item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 17px;
}
.c-maparea__table {
  border-collapse: collapse;
}
.c-maparea__table td,
.c-maparea__table th {
  border: 1px solid var(--border);
}
.c-maparea__table .c-area01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 62px;
  height: 30px;
  font-weight: 700;
  line-height: 1.5;
  color: var(--accent);
  background-color: #fff;
}
.c-maparea__table .c-area01--disable {
  pointer-events: none;
  color: var(--disabled);
}
.c-maparea__table td:empty {
  display: none;
  border: none;
  background: none;
}
.c-maparea__imgarea {
  width: clamp(16.6875rem, 19.7916666667vw + 7.1875rem, 25rem);
  position: absolute;
  top: clamp(-1.9375rem, -4.6130952381vw + 2.2142857143rem, 0rem);
  left: calc(50% - 76px);
  translate: -50% 0;
  z-index: -1;
}

.c-box02 {
  padding: 20px 24px 31px;
  background-color: var(--bg_02);
  border-bottom: 1px solid var(--border);
}
.c-box02__txt {
  margin-top: 8px;
}
.c-box02__groupbtns {
  margin-top: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 14px;
}
@media screen and (min-width: 768px) {
  .c-box02__ttl:hover::after {
    opacity: 0;
  }
}

.c-lead01 {
  font-weight: 700;
  line-height: 1.5;
  color: var(--accent);
  display: inline-block;
  position: relative;
  -webkit-transition: 0.5s all ease-in-out;
  transition: 0.5s all ease-in-out;
}
.c-lead01::after {
  content: "";
  position: absolute;
  bottom: 1px;
  left: 0;
  background-color: var(--accent);
  width: 100%;
  height: 1px;
  -webkit-transition: 0.5s all ease-in-out;
  transition: 0.5s all ease-in-out;
}
@media screen and (min-width: 768px) {
  .c-lead01::after {
    bottom: 2px;
  }
}

/* ==============================
   ① キーワード検索セクション
   ============================== */
.sec-search {
  background-color: #fff;
  padding: 70px 0 24px;
}
@media screen and (min-width: 768px) {
  .sec-search {
    padding: 100px 0 28px;
  }
}

/* ② 都道府県セクションの上部余白を縮小 */
.p-shop .sec02 {
  padding-top: 0;
}
@media screen and (min-width: 768px) {
  .p-shop .sec02 {
    padding-top: 0;
  }
}

/* ==============================
   検索ボックス共通スタイル
   ============================== */
.shop-search-box {
  max-width: 816px;
  margin-inline: auto;
  background: #fff;
  border: none;
  border-radius: 20px;
  padding: 32px 24px 36px;
  position: relative;
  box-shadow: 0 4px 24px rgba(247, 103, 0, 0.12), 0 1px 4px rgba(0,0,0,0.04);
  overflow: hidden;
}
/* 左端のアクセントライン */
.shop-search-box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  background: linear-gradient(180deg, #F76700 0%, #FF9A44 100%);
  border-radius: 20px 0 0 20px;
}
@media screen and (min-width: 768px) {
  .shop-search-box {
    padding: 40px 48px 44px;
  }
}

/* ② 都道府県ボックス */
.shop-search-box--pref {
  box-shadow: 0 4px 24px rgba(92, 77, 44, 0.10), 0 1px 4px rgba(0,0,0,0.04);
  padding: 28px 24px 32px;
  margin-bottom: 20px;
}
.shop-search-box--pref::before {
  background: linear-gradient(180deg, #5C4D2C 0%, #8B7A50 100%);
}
@media screen and (min-width: 768px) {
  .shop-search-box--pref {
    padding: 36px 48px 40px;
    margin-bottom: 28px;
  }
}

/* ==============================
   タイトル
   ============================== */
.shop-search-box__title {
  font-size: 1.1875rem;
  font-weight: 700;
  color: #333;
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1.4;
  padding-bottom: 12px;
  border-bottom: 2px solid #f0ebe3;
  margin-bottom: 4px;
}
@media screen and (min-width: 768px) {
  .shop-search-box__title {
    font-size: 1.5rem;
    padding-bottom: 16px;
  }
}
.shop-search-box__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, #F76700 0%, #FF9A44 100%);
  color: #fff;
  font-size: 1.0625rem;
  font-weight: 700;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(247, 103, 0, 0.25);
}
@media screen and (min-width: 768px) {
  .shop-search-box__number {
    width: 40px;
    height: 40px;
    font-size: 1.125rem;
  }
}
.shop-search-box--pref .shop-search-box__number {
  background: linear-gradient(135deg, #5C4D2C 0%, #8B7A50 100%);
  box-shadow: 0 2px 8px rgba(92, 77, 44, 0.25);
}
.shop-search-box--pref .shop-search-box__title {
  border-bottom-color: #e8e2d6;
}

/* ==============================
   説明文
   ============================== */
.shop-search-box__desc {
  margin-top: 12px;
  color: #777;
  font-size: 0.875rem;
  line-height: 1.7;
}

/* ==============================
   入力欄・ボタン
   ============================== */
.shop-search-box__input-wrap {
  margin-top: 20px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .shop-search-box__input-wrap {
    flex-wrap: nowrap;
  }
}
.shop-search-box__input {
  flex: 1;
  min-width: 0;
  width: 100%;
  padding: 14px 18px;
  border: 2px solid #e0dbd3;
  border-radius: 10px;
  font-size: 1rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  background-color: #FAFAF8;
}
.shop-search-box__input:focus {
  border-color: #F76700;
  box-shadow: 0 0 0 4px rgba(247, 103, 0, 0.10);
  background-color: #fff;
}
.shop-search-box__input::placeholder {
  color: #bbb;
  font-size: 0.875rem;
}
.shop-search-box__btn {
  padding: 14px 32px;
  background: linear-gradient(135deg, #F76700 0%, #FF8C33 100%);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: 0 3px 12px rgba(247, 103, 0, 0.25);
  letter-spacing: 0.05em;
}
.shop-search-box__btn:hover {
  background: linear-gradient(135deg, #e05a00 0%, #F76700 100%);
  box-shadow: 0 5px 20px rgba(247, 103, 0, 0.35);
  transform: translateY(-2px);
}
.shop-search-box__btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(247, 103, 0, 0.2);
}
.shop-search-box__clear {
  padding: 14px 22px;
  background-color: #fff;
  color: #888;
  border: 2px solid #e0dbd3;
  border-radius: 10px;
  font-size: 0.9375rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
  flex-shrink: 0;
}
.shop-search-box__clear:hover {
  border-color: #aaa;
  color: #333;
  background-color: #f9f9f7;
}

/* ==============================
   検索ステータス
   ============================== */
.shop-search-box__status {
  margin-top: 18px;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #F76700;
  line-height: 1.5;
}

/* ==============================
   検索結果エリア
   ============================== */
.shop-search-results {
  max-width: 816px;
  margin-inline: auto;
  margin-top: 24px;
  padding-bottom: 20px;
}
.shop-search-results__list .c-box02 {
  animation: fadeInUp 0.3s ease forwards;
  opacity: 0;
}
.shop-search-results__list .c-box02:nth-child(1) { animation-delay: 0s; }
.shop-search-results__list .c-box02:nth-child(2) { animation-delay: 0.05s; }
.shop-search-results__list .c-box02:nth-child(3) { animation-delay: 0.1s; }
.shop-search-results__list .c-box02:nth-child(4) { animation-delay: 0.15s; }
.shop-search-results__list .c-box02:nth-child(5) { animation-delay: 0.2s; }
.shop-search-results__list .c-box02:nth-child(n+6) { animation-delay: 0.25s; }

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* 都道府県ラベル（検索結果内） */
.shop-search-pref-label {
  display: inline-block;
  background: linear-gradient(135deg, #5C4D2C 0%, #8B7A50 100%);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: 20px;
  line-height: 1.5;
  letter-spacing: 0.05em;
}