/* common
------------------------------------------------ */
.maintitle { margin-bottom: 60px; }

@media screen and (min-width: 960px) {
  .maintitle { margin-bottom: 70px; }
}

/* utility
------------------------------------------------ */
.u-r-btn { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; text-align: left; font-family: inherit; font-weight: inherit; line-height: inherit; color: inherit; cursor: pointer; }
.u-r-input { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; text-align: left; font-family: inherit; font-weight: inherit; line-height: inherit; color: inherit; }

@media screen and (max-width: 959px) {
  .u-d-mobile { display: inherit !important; }
  .u-d-desktop { display: none !important; }
}

@media screen and (min-width: 960px) {
  .u-d-mobile { display: none !important; }
  .u-d-desktop { display: inherit !important; }
  .u-categories > span { padding: 4px 11px 3px; font-size: 1.2rem; }
}

/* shop
------------------------------------------------ */
/* common */
.shop { position: relative; }
.shop-announce { display: grid; gap: 5px; margin-bottom: 32px; width: 100%; font-size: 11px; line-height: 1.92; }
.shop-announce a { display: block; padding: 11px 10px; border: 1px solid #ddd; text-align: center; color: #f00; }
.shop-title { margin-bottom: 60px; text-align: center; }
.shop-title-name { margin-bottom: 13px; font-size: 11px; font-weight: 700; letter-spacing: 0.02em; line-height: 0.909090909; }
.shop-title-en { margin-bottom: 11px; font-size: 17px; font-weight: 700; letter-spacing: 0.02em; line-height: 0.5882352941; }
.shop-title-ja { font-size: 12px; font-weight: 400; letter-spacing: 0.05em; line-height: 1; }
.shop-title-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 5px; margin-top: 15px; }
.shop-title-tags > span { padding: 4px 7px; background-color: #000; font-size: 9px; font-weight: 700; letter-spacing: 0.05em; line-height: 1.2222222222; color: #fff; }
.shop-title-tags > span.is-flagship { background-color: #F1F1F1; color: #000; }

@media screen and (max-width: 959px) {
  .shop,
  .shop-announce { padding: 0 20px; }
}

@media screen and (min-width: 960px) {
  .shop,
  .shop-announce { margin: 0 auto; padding: 0 20px; max-width: 710px; }
  .shop-announce { margin-bottom: 32px; gap: 6px; font-size: 16px; }
  .shop-announce a { padding: 14px 15px; }
  .shop-title { margin-bottom: 60px; }
  .shop-title-name { margin-bottom: 9px; font-size: 13px; line-height: 1.5384615384; }
  .shop-title-en { margin-bottom: 14px; font-size: 22px; line-height: 0.909090909; }
  .shop-title-ja { font-size: 14px; line-height: 0.7142857142; }
  .shop-title-tags { gap: 6px; margin: 26px 0 -15px; }
  .shop-title-tags > span { padding: 8px 9px; font-size: 13px; line-height: 0.8461538461; }
}

/* find */
.shop-find-btn { margin-bottom: 15px; text-align: center; font-size: 11px; letter-spacing: 0.02em; line-height: 0.909090909; }
.shop-find-btn > a { display: flex; justify-content: center; align-items: center; gap: 11px; padding: 13px 10px; border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }
.shop-find-btn > a::before { content: ''; width: 12px; height: 15px; background: url(../img/shop-list/pin1.svg) no-repeat center center; background-size: 100%; }

@media screen and (min-width: 960px) {
  .shop-find-btn { margin-bottom: 16px; font-size: 16px; line-height: 0.625; }
  .shop-find-btn > a { gap: 11px; padding: 20px 10px; }
  .shop-find-btn > a::before { width: 14px; height: 18px; }
}

/* form */
.shop-form { margin-bottom: 60px; }
.shop-form form { display: block; position: relative; width: 100%; }
.shop-form fieldset { position: relative; border: none; }
.shop-form fieldset legend { display: none; }
.shop-form-keyword { display: block; padding: 0 36px 0 18px; width: 100%; height: 44px; background-color: #F5F5F5; border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; font-size: 11px; letter-spacing: 0.02em; line-height: 0.909090909; }
.shop-form-submit { position: absolute; top: 50%; right: 18px; transform: translateY(-50%); width: 14px; height: 15px; }

@media screen and (min-width: 960px) {
  .shop-form { margin-bottom: 100px; }
  .shop-form-keyword { padding: 0 52px 0 26px; height: 60px; font-size: 16px; }
  .shop-form-submit { right: 22px; width: 16px; height: 17px; }
}

/* area */
.shop-area-title { margin-bottom: 25px; text-align: center; font-size: 12px; font-weight: 700; letter-spacing: 0.05em; line-height: 0.9166666666; }
.shop-area-box__title > a,
.shop-area-box__trigger { display: block; position: relative; padding: 30px 20px; width: 100%; font-size: 13px; letter-spacing: 0.05em; line-height: 0.8461538461; }
.shop-area-box__title > a::after { content: ''; position: absolute; top: 50%; right: 24px; transform: translateY(-50%); width: 10px; height: 11px; background: url(../img/shop-list/arrow1.svg) no-repeat center center; background-size: 100%; }
.shop-area-box__trigger::before,
.shop-area-box__trigger::after { content: ''; position: absolute; top: 50%; right: 20px; transition: transform 0.4s ease; width: 11px; height: 1px; background-color: #000; }
.shop-area-box__trigger::after { transform: rotate(90deg); }
.shop-area-box__trigger[aria-expanded=true]::after { transform: rotate(0); }
.shop-area-box__content { display: none; padding-bottom: 40px; }
.shop-area-lists { background-color: #F1F1F1; border-radius: 4px; }
.shop-area-lists__item { font-size: 13px; letter-spacing: 0.05em; line-height: 0.8461538461; }
.shop-area-lists__item:not(:first-child) { border-top: 1px solid #fff; }
.shop-area-lists__item > a { display: block; position: relative; padding: 24px 25px; }
.shop-area-lists__item > a::after { content: ''; position: absolute; top: 50%; right: 24px; transform: translateY(-50%); width: 10px; height: 11px; background: url(../img/shop-list/arrow1.svg) no-repeat center center; background-size: 100%; }

@media screen and (max-width: 959px) {
  .shop-area-content { margin: 0 -20px; width: calc(100% + 40px); }
  .shop-area-box { border-bottom: 1px solid rgba(0,0,0,0.15); }
  .shop-area-box:first-child { border-top: 1px solid rgba(0,0,0,0.15); }
  .shop-area-box__content { margin: 0 20px; }
}

@media screen and (min-width: 960px) {
  .shop-area-title { margin-bottom: 40px; font-size: 18px; line-height: 0.6111111111; }
  .shop-area-content { border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }
  .shop-area-box:not(:first-child) { border-top: 1px solid rgba(0,0,0,0.15); }
  .shop-area-box__title > a,
  .shop-area-box__trigger { padding: 40px 30px; font-size: 16px; line-height: 0.6111111111; }
  .shop-area-box__trigger::before,
  .shop-area-box__trigger::after { width: 11px; height: 1px; right: 30px; }
  .shop-area-box__title > a::after { right: 30px; width: 10px; height: 11px; }
  .shop-area-box__content { margin: 0 30px; padding-bottom: 40px; }
  .shop-area-lists__item { font-size: 15px; line-height: 0.7333333333; }
  .shop-area-lists__item > a { padding: 24px 25px; }
  .shop-area-lists__item > a::after { right: 30px; width: 10px; height: 11px; }
}

/* lists */
.shop-lists-item { padding: 40px 20px; }
.shop-lists-title { margin-bottom: 20px; }
.shop-lists-title__en { margin-bottom: 11px; font-size: 15px; font-weight: 700; letter-spacing: 0.02em; line-height: 0.6666666666; }
.shop-lists-title__ja { font-size: 11px; font-weight: 700; letter-spacing: 0.05em; line-height: 1.0909090909; }
.shop-lists-tags { display: flex; flex-wrap: wrap; gap: 5px; margin: -4px 0 20px; }
.shop-lists-tags > span { padding: 4px 7px; background-color: #000; font-size: 9px; font-weight: 700; letter-spacing: 0.05em; line-height: 1.2222222222; color: #fff; }
.shop-lists-tags > span.is-flagship { background-color: #F1F1F1; color: #000; }
.shop-lists-box__title { font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-lists-box__title:not(:first-child) { margin-top: 13px; }
.shop-lists-box__text { font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-lists-box__text.is-announce { color: #f00; }
.shop-lists-distance { display: flex; justify-content: flex-end; align-items: center; gap: 9px; margin: -25px 0 30px; font-size: 15px; letter-spacing: 0.02em; line-height: 0.6666666666; }
.shop-lists-distance::before { content: ''; width: 15px; height: 20px; background: url(../img/shop-list/pin1.svg) no-repeat center center; background-size: 100%; }
.shop-lists-btns { display: grid; gap: 11px; grid-template-columns: repeat(2,calc(50% - (11px / 2))); margin-top: 24px; }
.shop-lists-btns__item { text-align: center; font-size: 12px; letter-spacing: 0.05em; line-height: 1; }
.shop-lists-btns__item > a { display: block; padding: 13px 10px; width: 100%; border: 1px solid #000; border-radius: 4px; }
.shop-lists-btns__item.is-reservation { font-weight: 700; }
.shop-lists-btns__item.is-detail > a { border-color: rgba(0,0,0,0.15); }

@media screen and (max-width: 959px) {
  .shop-lists { margin: 0 -20px; width: calc(100% + 40px); }
  .shop-lists-item { border-bottom: 1px solid rgba(0,0,0,0.15); }
}

@media screen and (min-width: 960px) {
  .shop-lists-item { padding: 50px; }
  .shop-lists-item:not(:last-child) { border-bottom: 1px solid rgba(0,0,0,0.15); }
  .shop-lists-title { margin-bottom: 38px; }
  .shop-lists-title__en { margin-bottom: 15px; font-size: 20px; line-height: 0.5; }
  .shop-lists-title__ja { font-size: 14px; line-height: 0.8571428571; }
  .shop-lists-tags { gap: 6px; margin: -17px 0 38px; }
  .shop-lists-tags > span { padding: 8px 9px; font-size: 13px; line-height: 0.8461538461; }
  .shop-lists-box__title { margin-bottom: 6px; font-size: 16px; line-height: 1.3125; }
  .shop-lists-box__title:not(:first-child) { margin-top: 17px; }
  .shop-lists-box__text { font-size: 16px; line-height: 1.625; }
  .shop-lists-distance { gap: 10px; margin: -22px 0 0; font-size: 20px; line-height: 0.5; }
  .shop-lists-distance::before { width: 15px; height: 20px; }
  .shop-lists-btns { gap: 16px; grid-template-columns: repeat(2,calc(50% - (16px / 2))); margin-top: 33px; }
  .shop-lists-btns__item { font-size: 16px; line-height: 0.75; }
  .shop-lists-btns__item > a { padding: 21px 10px 20px; }
}

/* result */
.shop-result-notfound__text { text-align: center; font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-result-notfound__back { margin-top: 24px; text-align: center; font-size: 12px; letter-spacing: 0.05em; line-height: 1; }
.shop-result-notfound__back > a { display: block; margin: 0 auto; padding: 13px 10px; width: 100%; max-width: 162px; border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }

@media screen and (max-width: 959px) {
  .shop-result .shop-lists { border-top: 1px solid rgba(0,0,0,0.15); }
}

@media screen and (min-width: 960px) {
  .shop-result-content { border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }
  .shop-result-notfound__text { font-size: 16px; line-height: 1.3125; }
  .shop-result-notfound__back { margin-top: 46px; font-size: 16px; line-height: 0.75; }
  .shop-result-notfound__back > a { padding: 21px 10px 20px; max-width: 277px; }
}

/* find */
.shop-find-title { margin-bottom: 20px; text-align: center; font-size: 12px; font-weight: 700; letter-spacing: 0.05em; line-height: 0.9166666666; }
.shop-find-content { display: none; }
.shop-find-map { position: relative; aspect-ratio: 1 / 1.0666666666; overflow: hidden; }
.shop-find-none { text-align: center; font-size: 12px; }
.shop-find-loading { position: fixed; top: 0; left: 0; transition: opacity 0.4s ease; width: 100%; height: 100%; background: url(../img/shop-list/loading.gif) no-repeat center center rgba(0,0,0,0.6); background-size: 60px; z-index: 100; }
.shop-find-loading.is-hidden { pointer-events: none; opacity: 0; }

@media screen and (max-width: 959px) {
  .shop-find-map { margin: 0 -20px; width: calc(100% + 40px); }
}

@media screen and (min-width: 960px) {
  .shop-find-title { margin-bottom: 30px; font-size: 18px; line-height: 0.6111111111; }
  .shop-find-content { border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }
  .shop-find-map { aspect-ratio: 1 / 0.6641791044; }
  .shop-find-none { font-size: 16px; }
}

/* detail */
.shop-detail { position: relative; margin-top: -10px; }
.shop-detail-map { position: relative; aspect-ratio: 1 / 1.0666666666; width: 100%; overflow: hidden; }
.shop-detail-map iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.shop-detail-box { padding-bottom: 25px; border-bottom: 1px solid rgba(0,0,0,0.15); }
.shop-detail-box__title { margin-bottom: 3px; font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-detail-box__title:not(:first-child) { margin-top: 25px; padding-top: 20px; border-top: 1px solid rgba(0,0,0,0.15); }
.shop-detail-box__text { font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-detail-box__text.is-announce { color: #f00; }
.shop-detail-box__lists > li { position: relative; padding-left: 1em; }
.shop-detail-box__lists > li::before { content: '\30FB'; position: absolute; top: 0; left: 0; }
.shop-detail-note { margin-top: 25px; font-size: 12px; letter-spacing: 0.05em; line-height: 1.75; }
.shop-detail-btns { display: grid; gap: 12px; margin-top: 40px; }
.shop-detail-btns__item { text-align: center; font-size: 12px; letter-spacing: 0.05em; line-height: 1; }
.shop-detail-btns__item > a { display: block; padding: 14px 10px 16px; width: 100%; border: 1px solid #000; border-radius: 4px; }
.shop-detail-btns__item.is-reservation { font-weight: 700; }
.shop-detail-btns__item.is-news > a { border-color: rgba(0,0,0,0.15); }

@media screen and (max-width: 959px) {
  .shop-detail-map { margin: 0 -20px 30px; width: calc(100% + 40px); }
}

@media screen and (min-width: 960px) {
  .shop-detail { margin-top: -5px; padding: 0 50px 50px; border: 1px solid rgba(0,0,0,0.15); border-radius: 4px; }
  .shop-detail-map { margin: 0 -50px 47px; aspect-ratio: 1 / 0.6641791044; width: calc(100% + 100px); }
  .shop-detail-box { padding-bottom: 30px; }
  .shop-detail-box__title { margin-bottom: 8px; font-size: 16px; line-height: 1.3125; }
  .shop-detail-box__title:not(:first-child) { margin-top: 30px; padding-top: 30px; }
  .shop-detail-box__text { font-size: 16px; }
  .shop-detail-note { margin-top: 30px; font-size: 16px; }
  .shop-detail-btns { gap: 16px; grid-template-columns: repeat(2,calc(50% - (16px / 2))); margin-top: 46px; }
  .shop-detail-btns__item { font-size: 16px; line-height: 0.75; }
  .shop-detail-btns__item > a { padding: 21px 10px 20px; }
}