@charset "UTF-8";
/*//////////////////////////////////////////////////////////

Copyright (C) apricot-design All Rights Reserved.
------------------------------------------------------------
CSS information
 file name  :  reset.css
 style info :  リセットファイル
 admin info :  apricot-design

//////////////////////////////////////////////////////////*/
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section {
  display: block;
}

audio[controls], canvas, video {
  display: inline-block;
  *display: inline;
  zoom: 1;
}

html {
  overflow-y: scroll;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body, div, dl, dt, dd, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td, ul {
  margin: 0;
  padding: 0;
}

body, button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b, strong {
  font-weight: bold;
}

blockquote {
  margin: 1em 40px;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

pre, code, kbd, samp {
  font-family: monospace, monospace;
  _font-family: "courier new", monospace;
  font-size: 1em;
}

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
}

q {
  quotes: none;
}
q:before, q:after {
  content: "";
  content: none;
}

small {
  font-size: inherit;
}

sub {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

ul, ol {
  margin: 0;
  padding: 0;
}

dd {
  margin: 0px;
}

nav ul, nav ol {
  list-style: none;
}

img {
  border: 0;
  -ms-interpolation-mode: bicubic;
}

svg:not(:root) {
  overflow: hidden;
}

figure, form {
  margin: 0;
}

fieldset {
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  *margin-left: -7px;
}

button, input, select, textarea {
  font-size: 100%;
  margin: 0;
  vertical-align: baseline;
  *vertical-align: middle;
}

button, input {
  line-height: normal;
  *overflow: visible;
}

button {
  cursor: pointer;
  -webkit-appearance: button;
  padding: 0;
  border: none;
  background-color: transparent;
}

input[type=button], input[type=reset], input[type=submit] {
  cursor: pointer;
  -webkit-appearance: button;
}
input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
}
input[type=search] {
  -webkit-appearance: textfield;
  box-sizing: content-box;
}
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  font-size: 100%;
}

img, abbr, acronym, fieldset {
  border: 0;
}

li {
  list-style: none;
}

/*画像を縦に並べた時に余白が出ないように*/
img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

/*box-sizingを全ブラウザに対応*/
* {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
*:before, *:after {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.ie6_error, .no_script {
  background: #F66;
  padding: 100px;
  text-align: center;
  font-size: 150%;
  color: #333;
}

.mincho {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

.gothic {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
}

.zen {
  font-family: "Zen Maru Gothic", sans-serif;
}

.en {
  font-family: "Jost", sans-serif;
}

:root {
  --extend: min(calc(( 50vw - 50% ) * -1), 0px);
  --sideW: min(6.66vw, 25px);
  --headerHeight: 110px;
  --contentsWideS: 270px;
  --contentsWideM: 1220px;
  --contentsWideL: 1360px;
  --contentWidePc: 375px;
}

@media screen and (max-width: 767px) {
  :root {
    --sideW: 6.66vw;
    --headerHeight: 82px;
    --sectionWrap: 3.75em;
    --contentWidePc: 100%;
  }
}
html {
  width: 100%;
  scroll-behavior: smooth;
}

body {
  font: 400 16px/1.8 "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  letter-spacing: 0.06em;
  color: #6D2100;
  text-align: left;
  counter-reset: number 0;
}

.l_container_wrap {
  position: relative;
}

.l_container {
  position: relative;
}

.section_wrap {
  padding: 5em 0 7.5em;
}

.inner, .inner_l, .inner_m, .inner_s, [data-popup=treehouse] .box_beige__inner,
[data-popup=artist] .box_beige__inner {
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--sideW);
}

.inner_s, [data-popup=treehouse] .box_beige__inner,
[data-popup=artist] .box_beige__inner {
  max-width: calc(var(--contentsWideS) + var(--sideW) * 2);
}

.inner_m {
  max-width: calc(var(--contentsWideM) + var(--sideW) * 2);
}

.inner_l {
  max-width: calc(var(--contentsWideL) + var(--sideW) * 2);
}

.add_ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.2em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-top: 1.5em;
  margin-bottom: 0.875em !important;
}

.add_ttl_02 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.0666em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-top: 1.5em;
  margin-bottom: 0.875em !important;
}

a.add_link {
  text-decoration: underline;
}
a.add_link:hover {
  opacity: 0.7;
}

.login h1 a {
  width: 100px !important;
  height: 100px !important;
  background: url(../images/login_logo.png) no-repeat center/contain !important;
}

.post_content {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.75;
}
.post_content > * {
  margin-bottom: 1.5em;
}
.post_content > *:first-child {
  margin-top: 0 !important;
}
.post_content > *:last-child {
  margin-bottom: 0 !important;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.3s;
}
a:link, a:active, a:visited {
  text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
  color: inherit;
  font-weight: inherit;
  line-height: 1.5;
}

label {
  cursor: pointer;
}

button {
  padding: 0;
  border: none;
  color: inherit;
}

picture {
  display: contents;
}
picture img {
  display: block;
}

img {
  max-width: 100%;
  height: auto;
}
img[src$=".svg"] {
  max-width: 100%;
  width: auto;
}

.opacity {
  transition: 0.5s;
}
@media (hover: hover) {
  .opacity:hover {
    opacity: 0.5;
  }
}

@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

.img_only {
  display: block;
}
.img_only img {
  display: block;
  width: 100%;
}

.text_link {
  text-decoration: underline !important;
}

input[type=text],
input[type=email],
input[type=tel],
textarea {
  width: 100%;
  padding: 0.5em;
  border-radius: 0;
  border: 1px solid rgba(109, 33, 0, 0.5);
  background: #fff;
  color: inherit;
  font-family: inherit;
  line-height: inherit;
  font-size: 16px !important;
}

select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: 0.5em 28px 0.5em 0.5em;
  border-radius: 0;
  border: 1px solid rgba(109, 33, 0, 0.5);
  background: url(../images/icon_tri_select.svg) no-repeat center right 10px/10px 8px #fff;
  color: inherit;
  font-family: inherit;
  line-height: inherit;
  font-size: 16px !important;
}

textarea {
  height: 15em;
}

input[type=checkbox] {
  accent-color: #00A6DD;
  inline-size: 1.2em;
  block-size: 1.2em;
}

input[type=radio] {
  accent-color: #00A6DD;
  inline-size: 1.2em;
  block-size: 1.2em;
}

.dlist_form {
  padding-bottom: 3.75em;
  margin-bottom: 3.75em;
  border-bottom: 1px dashed #6D2100;
}
.dlist_form .group {
  display: flex;
  align-items: baseline;
  gap: 1em;
}
@media screen and (max-width: 767px) {
  .dlist_form .group {
    flex-direction: column;
  }
}
.dlist_form .group:not(:last-of-type) {
  margin-bottom: 2.5em;
}
.dlist_form .group dt {
  width: 244px;
  flex-shrink: 0;
  font-weight: 700;
}
.dlist_form .group dt.require:after {
  content: "必須";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 0.8375em;
  font-weight: 700;
  color: #fff;
  background-color: #00A6DD;
  width: 4.7em;
  height: 2.2em;
  margin-left: 1em;
}
.dlist_form .group dd {
  flex-grow: 1;
}
.dlist_form .group dd .list_kome {
  font-size: 0.875em;
  padding-top: 1em;
}

.container_checkbox {
  background-color: #F8F8F8;
  height: 100px;
  display: grid;
  place-content: center;
  font-size: 1rem;
  font-weight: 700;
}
.container_checkbox input[type=checkbox] {
  width: 30px;
  background-image: url(../images/icon_checkbox_02.svg);
}
.container_checkbox input[type=checkbox]:checked {
  background-image: url(../images/icon_checkbox_checked_02.svg);
}

.wpcf7-response-output,
.wpcf7-spinner {
  display: none !important;
}

.grecaptcha-badge {
  visibility: hidden;
}

@keyframes fade_in {
  80% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 1;
  }
}
[class^=fade_anim] {
  opacity: 0;
}
[class^=fade_anim].js-active {
  animation: fade_in 1s ease-out forwards;
}

.fade_anim.js-active {
  animation: fade_in 1s ease-in forwards;
}

.fade_anim_bottom {
  transform: translate(0, 60px);
}

.fade_anim_left {
  transform: translate(-40px, 0);
}

.fade_anim_right {
  transform: translate(60px, 0);
}

.l_container_wrap:before {
  position: fixed;
  content: "";
  display: block;
  width: 100%;
  height: 100vh;
  background: url(../images/bg_pc.jpg) no-repeat center/cover;
}

.l_contents {
  width: 100%;
  max-width: var(--contentWidePc);
  margin: 0 auto;
  background-color: #fff;
}

.btn_reserve {
  position: fixed;
  z-index: 1;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: var(--contentWidePc);
  height: 80px;
  background-color: #ED8D12;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.btn_reserve:after {
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: 40px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_orange.svg) no-repeat center/50%;
}
.btn_reserve span span {
  display: none;
  font-size: 0.625em;
}
.btn_reserve.is-yet {
  pointer-events: none;
}
.btn_reserve.is-yet:after {
  content: none;
}
.btn_reserve.is-yet span span {
  display: block;
  font-size: 0.625em;
}

.btn_cmn_01 {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 270px;
  height: 48px;
  margin: 0 auto;
  padding: 0 8.88%;
  background-color: #ED8D12;
  border-radius: 50px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  position: relative;
}
.btn_cmn_01:after {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_orange.svg) no-repeat center/50%;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}

.list_kome > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_kome > li:before {
  content: "※";
}

.list_dot > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_dot > li:before {
  content: "・";
}

.list_ast > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_ast > li:before {
  content: "＊";
}

.list_maru > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_maru > li:before {
  content: "●";
}

.list_number {
  counter-reset: number 0;
}
.list_number > li {
  counter-increment: number 1;
}
.list_number > li:before {
  content: counter(number);
}

.navigation.pagination {
  margin-top: 32px;
}
.navigation.pagination .nav-links {
  text-align: center;
  font-size: 0;
}
.navigation.pagination .nav-links .page-numbers {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  aspect-ratio: 1/1;
  border-radius: 4px;
  background-color: #fff;
  color: #077C65;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.05;
  margin-right: 8px;
}
.navigation.pagination .nav-links .page-numbers:last-child {
  margin-right: 0;
}
.navigation.pagination .nav-links .page-numbers.current {
  background-color: #077C65;
  color: #fff;
}

.single_pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 32px;
}
.single_pagination li {
  width: 40px;
  flex-shrink: 0;
}
.single_pagination li.prev a {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_green.svg) no-repeat center/50%;
  transform: rotate(180deg);
}
.single_pagination li.archive {
  flex-grow: 1;
  text-align: center;
}
.single_pagination li.archive a {
  color: #077C65;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  text-decoration: underline;
}
.single_pagination li.next {
  width: 40px;
  flex-shrink: 0;
}
.single_pagination li.next a {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_green.svg) no-repeat center/50%;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  opacity: 1;
  visibility: visible;
  transition: 0.5s;
}
.loading.end {
  opacity: 0;
  visibility: hidden;
}

.hbm_btn {
  padding: 0;
  border: none;
  background-color: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 48px;
  aspect-ratio: 1/1;
  position: relative;
  background-color: #ED8D12;
  border-radius: 50%;
  margin-left: auto;
}
.hbm_btn .box {
  display: block;
  width: 50%;
  position: relative;
}
.hbm_btn .box .bar {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 50px;
  background-color: #fff;
  position: absolute;
  left: 0;
  transition: 0.3s;
}

[data-hbm-bar="3"] .box {
  aspect-ratio: 24/16;
  margin: 15% 0;
}
[data-hbm-bar="3"] .bar:nth-child(1) {
  top: -1px;
}
[data-hbm-bar="3"] .bar:nth-child(2) {
  top: calc(50% - 1px);
}
[data-hbm-bar="3"] .bar:nth-child(3) {
  top: calc(100% - 1px);
}
[data-hbm-bar="3"].js-active .bar:nth-child(1) {
  top: calc(50% - 1px);
  transform: rotate(135deg);
}
[data-hbm-bar="3"].js-active .bar:nth-child(2) {
  top: calc(50% - 1px);
  transform: rotateY(90deg);
}
[data-hbm-bar="3"].js-active .bar:nth-child(3) {
  top: calc(50% - 1px);
  transform: rotate(-135deg);
}

[data-hbm-bar="2"] .box {
  aspect-ratio: 3/1;
  margin: 15% 0;
}
[data-hbm-bar="2"] .bar:nth-child(1) {
  top: 0;
}
[data-hbm-bar="2"] .bar:nth-child(2) {
  top: 100%;
}
[data-hbm-bar="2"].js-active .bar:nth-child(1) {
  top: 50%;
  transform: rotate(160deg);
}
[data-hbm-bar="2"].js-active .bar:nth-child(2) {
  top: 50%;
  transform: rotate(-160deg);
}

.hbm_content {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #6D2100;
  color: #fff;
  overflow: scroll;
  visibility: hidden;
  opacity: 0;
  transition: all 0.3s;
}
.hbm_content.js-active {
  visibility: visible;
  opacity: 1;
}
.hbm_content .inner_s, .hbm_content [data-popup=treehouse] .box_beige__inner, [data-popup=treehouse] .hbm_content .box_beige__inner,
.hbm_content [data-popup=artist] .box_beige__inner,
[data-popup=artist] .hbm_content .box_beige__inner {
  margin: 5em auto;
}
.hbm_content .copyright {
  margin-top: 40px;
  color: #BEA297;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  text-align: center;
}

.header {
  width: 100%;
  max-width: var(--contentWidePc);
  position: fixed;
  z-index: 3;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px;
}

.header_contact {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 56px;
  background-color: #9A6852;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  border-radius: 5px;
  margin-top: 30px;
  position: relative;
}
.header_contact:before {
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 32/24;
  background: url(../images/footer_04.svg) no-repeat center/contain;
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
}

.top_about {
  background-color: #FFFBDE;
  padding: 50px 0;
}
.top_about .box_blue {
  background-color: #00A6DD;
  border-radius: 20px;
  padding: 40px var(--sideW);
  position: relative;
}
.top_about .box_blue:after {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 28/40;
  background: url(../images/top_about_04.svg) no-repeat center/contain;
  position: absolute;
  top: 100%;
  left: var(--sideW);
  transform: translateY(-50%);
}
.top_about ul {
  max-width: 269px;
  margin: 0 auto;
}
.top_about ul li {
  margin-bottom: 28px;
}
.top_about ul li:nth-child(3) p {
  color: #fff;
  font-size: 0.9375em;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0;
}
.top_about ul li:last-child {
  margin-bottom: 0;
}
.top_about h2 {
  text-align: center;
  color: #00A6DD;
  background: url(../images/top_about_01.svg) no-repeat center/auto 100%;
  padding: 1px 0;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 20px;
}

.dlist_sponsor .group {
  font-size: 0.75em;
  font-weight: 700;
  line-height: 1.5;
  display: flex;
  align-items: baseline;
  color: #fff;
}
.dlist_sponsor .group dt {
  flex-shrink: 0;
}
.dlist_sponsor .group dt:before {
  content: "●";
}
.dlist_sponsor .group dt:after {
  content: "：";
}

.top_enquete {
  background: #FFFBDE url(../images/top_enquete_01.png) no-repeat bottom right/cover;
  padding: 36px 0 52px;
}
.top_enquete h2 {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 20px;
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.3;
  position: relative;
}
.top_enquete h2:before {
  content: "";
  display: block;
  width: 32px;
  height: 50px;
  background: url(../images/top_enquete_02.svg) no-repeat center/contain;
  position: absolute;
  top: 10px;
  right: calc(100% + 4px);
}
.top_enquete h2:after {
  content: "";
  display: block;
  width: 32px;
  height: 50px;
  background: url(../images/top_enquete_03.svg) no-repeat center/contain;
  position: absolute;
  top: 10px;
  left: calc(100% + 4px);
}
.top_enquete p {
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 2;
  margin-bottom: 1.5em;
}
.top_enquete a {
  display: flex;
  align-items: center;
  width: 100%;
  height: 48px;
  padding: 0 8.88%;
  background-color: #ED8D12;
  border-radius: 50px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  position: relative;
}
.top_enquete a:after {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_orange.svg) no-repeat center/50%;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}

.top_faq {
  background-color: #FFFBDE;
  padding: 2.5em 0 6em;
}
.top_faq h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.45;
  text-align: center;
  margin-bottom: 1em;
}
.top_faq h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_faq_01.svg) no-repeat center/contain;
  margin: 0 auto 4px;
}
.top_faq .list_faq > li {
  margin-bottom: 1.5em;
}
.top_faq .list_faq > li:last-child {
  margin-bottom: 0;
}
.top_faq h3 {
  cursor: pointer;
  background-color: #6D2100;
  color: #fff;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  border-radius: 10px 10px 10px 10px;
  padding: 1.25em 8.6%;
  transition: 0.3s;
  position: relative;
}
.top_faq h3 .icon {
  position: absolute;
  top: 50%;
  right: 4.92%;
  transform: translateY(-50%);
  display: block;
  width: 40px;
  aspect-ratio: 1/1;
  border: 1px solid #fff;
  border-radius: 50%;
}
.top_faq h3 .icon:before, .top_faq h3 .icon:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 50%;
  height: 3px;
  border-radius: 50px;
  background-color: #fff;
}
.top_faq h3 .icon:after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.top_faq h3.js-active {
  border-radius: 10px 10px 0px 0px;
}
.top_faq h3.js-active .icon:after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.dlist_faq {
  padding: 0 10px;
  background-color: #fff;
}
.dlist_faq .group {
  padding: 1.5em 10px;
  position: relative;
}
.dlist_faq .group:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.dlist_faq .group:last-child:after {
  content: none;
}
.dlist_faq dt {
  cursor: pointer;
  position: relative;
  padding-right: 30px;
}
.dlist_faq dt:before, .dlist_faq dt:after {
  content: "";
  display: block;
  width: 14px;
  height: 2px;
  border-radius: 50px;
  background-color: #BEA297;
  position: absolute;
  top: 10px;
  right: 0;
}
.dlist_faq dt:after {
  transform: rotate(90deg);
}
.dlist_faq dt .text {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.dlist_faq dt .text:before {
  content: "Q.";
  color: #BEA297;
  flex-shrink: 0;
}
.dlist_faq dd .container {
  padding: 16px 0 0;
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 0.9375em;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.dlist_faq dd .container:before {
  content: "A.";
  font-weight: 700;
  color: #BEA297;
  flex-shrink: 0;
}
.dlist_faq dd .container a {
  color: blue;
  text-decoration: underline;
}

.top_quest {
  background: url(../images/top_quest_01.jpg) repeat-y center top/100% auto;
  padding: 2.5em 0 5em;
}
.top_quest h2 {
  margin: -86px -10px 10px;
}
.top_quest h2 + p {
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 45px;
}

.quest_contents_01 {
  width: 100%;
  max-width: var(--contentsWideS);
  margin: 0 auto;
}
.quest_contents_01 .area_label {
  color: #fff;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  padding: 4px;
  border-radius: 50px;
  text-align: center;
  background-color: #E07518;
  margin-bottom: 1em;
}
.quest_contents_01 .area_label.green_1 {
  background-color: #7DB450;
}
.quest_contents_01 .area_label.green_2 {
  background-color: #22542D;
}
.quest_contents_01 .area_label.green_3 {
  background-color: #1B7E47;
}

.splide__track {
  overflow: visible;
}
.splide__arrow {
  opacity: 1;
  background: #6D2100 url(../images/ico_arrow_01_white.svg) no-repeat center/50%;
  width: 40px;
  height: auto;
  aspect-ratio: 1/1;
}
.splide__arrow svg {
  display: none;
}
.splide__arrow--prev {
  transform: translateY(-50%) rotate(180deg);
  left: -28px;
}
.splide__arrow--next {
  right: -28px;
}
.splide__arrow:disabled {
  display: none;
}
.splide__pagination {
  position: static;
  padding: 0;
  margin-top: 8px;
}
.splide__pagination li button {
  opacity: 1;
  transform: none !important;
  background-color: #BEA297;
  margin: 3px 8px;
}
.splide__pagination li button.is-active {
  background-color: #6D2100;
}

.quest_slide_01,
.quest_slide_02,
.quest_slide_03 {
  margin-bottom: 40px;
}

.quest_slide_04 {
  margin-bottom: 80px;
}

.card_quest {
  background-color: #fff;
  border-radius: 10px;
  overflow: hidden;
  height: 100%;
}
.card_quest .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 269/174;
}
.card_quest .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_quest .text {
  padding: 20px 7.6%;
}
.card_quest .label {
  width: -moz-fit-content;
  width: fit-content;
  background-color: #E07518;
  color: #fff;
  font-size: 0.8125em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  padding: 2px 8px 1px;
  border-radius: 2px;
  margin-bottom: 4px;
}
.card_quest .ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: 6px;
}
.card_quest .descr {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_quest .reserve {
  margin-top: 16px;
}
.card_quest .reserve dt {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.2;
  margin-bottom: 8px;
}
.card_quest .reserve dt span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 18px;
  font-size: 0.875rem;
  font-weight: 700;
  background-color: #6D2100;
  color: #fff;
  padding-top: 1px;
}
.card_quest .reserve dd {
  border-top: 1px solid #6D2100;
  border-bottom: 1px solid #6D2100;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  padding: 8px 2px;
}
.card_quest .price {
  margin-top: 22px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.card_quest .price dt {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 58px;
  height: 18px;
  font-size: 0.875rem;
  font-weight: 700;
  background-color: #6D2100;
  color: #fff;
  padding-top: 1px;
}
.card_quest .price dd {
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

.card_quest_02 .label {
  background-color: #7DB450;
}

.card_quest_03 .label {
  background-color: #22542D;
}

.card_quest_04 .label {
  background-color: #1B7E47;
}

.card_quest_05 .label {
  background-color: #00A6DD;
}

.quest_announce {
  background-color: #fff;
  border-radius: 10px;
  padding: 24px 0;
  text-align: center;
  margin-bottom: 5em;
}
.quest_announce dt {
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: 1em;
}
.quest_announce dd {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

.list_quest_other > li {
  margin-bottom: 32px;
}
.list_quest_other > li:last-child {
  margin-bottom: 0;
}

.result {
  width: 100%;
  aspect-ratio: 325/184;
  background: url(../images/top_quest_03.png) no-repeat center/contain;
  position: relative;
  padding: 13.53% 8% 0;
  margin-bottom: 54px;
}
.result:after {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 64/65;
  background: url(../images/top_quest_04.svg) no-repeat center/contain;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.result p {
  color: #FCF200;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 8px;
}
.result .list_kome {
  color: #fff;
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

.list_quest {
  margin: 0 calc(var(--sideW) * -1);
  padding: 0 var(--sideW);
  overflow: hidden;
}
.list_quest h3 {
  width: 100%;
  max-width: 270px;
  margin: 0 auto 24px;
  font-family: "Zen Maru Gothic", sans-serif;
  text-align: center;
  font-size: 1.5em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.45;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.list_quest h3:before {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 28/46;
  background: url(../images/top_quest_05.svg) no-repeat center/contain;
}
.list_quest h3:after {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 28/46;
  background: url(../images/top_quest_06.svg) no-repeat center/contain;
}
.list_quest h3 .small {
  display: block;
  font-size: 0.75em;
}

.quest_marker {
  margin-top: 5em;
}
.quest_marker dt {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 20px;
}
.quest_marker dd .image {
  width: 100%;
  max-width: var(--contentsWideS);
  margin: 0 auto 28px;
}
.quest_marker dd .list_kome {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.quest_marker dd .list_kome a {
  text-decoration: underline;
}

.top_workshop {
  background-color: #FFFBDE;
  padding: 2.5em 0 4em;
}
.top_workshop h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  margin-bottom: 24px;
}
.top_workshop h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_workshop_01.svg?ver=1.0) no-repeat center/contain;
  margin: 0 auto 4px;
}

.card_workshop {
  border-radius: 10px;
  background-color: #fff;
  overflow: hidden;
}
.card_workshop .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 325/217;
}
.card_workshop .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_workshop .text {
  padding: 20px 0 32px;
}
.card_workshop .ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.44;
  margin-bottom: 16px;
}
.card_workshop .descr {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.6;
}
.card_workshop .descr .list_kome li {
  font-size: inherit;
}
.card_workshop .dlist_workshop {
  margin-top: 20px;
}
.card_workshop .dlist_workshop .group {
  display: flex;
  flex-wrap: wrap;
  gap: 0 8px;
  margin-bottom: 6px;
}
.card_workshop .dlist_workshop dt {
  background-color: #6D2100;
  color: #fff;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 8px;
}
.card_workshop .dlist_workshop dd {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_workshop .dlist_workshop dd:nth-child(3) {
  margin-top: 10px;
  width: 100%;
  border-top: 1px solid #6D2100;
  border-bottom: 1px solid #6D2100;
  font-size: 0.8125rem;
  padding: 8px 2px;
}
.card_workshop .intro {
  margin-top: 3em;
}
.card_workshop .intro .image {
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 22px;
}
.card_workshop .intro .name {
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: 0.5em;
}
.card_workshop .intro .name + p {
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
}
.card_workshop .intro .instagram {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_workshop .intro .instagram:before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  background: url(../images/ico_instagram_textcolor.svg) no-repeat center/contain;
}
.card_workshop.chicken .text {
  background-color: #6D2100;
}
.card_workshop.chicken .ttl {
  color: #FCF200;
  margin-bottom: 0;
  text-align: center;
}
.card_workshop.chicken .ttl span {
  color: #fff;
  font-size: 0.8em;
}
.card_workshop.chicken .descr {
  color: #fff;
  margin-top: 1.25em;
}

.card_workshop + .card_workshop {
  margin-top: 2.5em;
}

.top_map {
  background: url(../images/top_quest_01.jpg) repeat-y center top/100% auto;
  padding: 2.5em 0 4em;
}
.top_map h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  margin-bottom: 30px;
}
.top_map h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_map_01.svg?ver=1.0) no-repeat center/contain;
  margin: 0 auto 4px;
}
.top_map h2 + p {
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 1em;
}
.top_map .list_kome {
  margin-bottom: 2em;
}
.top_map .list_kome li {
  font-size: 0.875em;
  letter-spacing: 0;
  line-height: 1.5;
}
.top_map .bnr {
  display: block;
}
.top_map .bnr_flyer {
  margin-top: 50px;
}

.list_area {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}
.list_area li {
  width: calc((100% - 13px) / 2);
}
.list_area li a {
  display: block;
  width: 100%;
  border-radius: 50px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.2;
  text-align: center;
  padding: 8px 0;
  background: #00718E url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-21 {
  background: #00718E url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-20 {
  background: #E47400 url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-19 {
  background: #007B40 url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-18 {
  background: #988B25 url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-17 {
  background: #00A3CF url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}
.list_area li a.shop_area-16 {
  background: #8F3C2B url(../images/ico_arrow_01_white.svg) no-repeat center right 8px/11px;
}

.top_timetable {
  background: #FFFBDE;
  padding: 2.5em 0 4em;
}
.top_timetable h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  margin-bottom: 30px;
}
.top_timetable h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_timetable_01.svg) no-repeat center/contain;
  margin: 0 auto 4px;
}
.top_timetable .bnr {
  display: block;
}
.top_timetable .bnr + .bnr {
  margin-top: 50px;
}

.dlist_timetable {
  background-color: #077C65;
  padding: 20px;
  border-radius: 20px;
  margin-bottom: 56px;
}
.dlist_timetable .group {
  background: #fff;
  border-radius: 5px;
  margin-bottom: 8px;
  padding: 12px;
}
.dlist_timetable .group:nth-child(even) {
  background-color: #DAE7C4;
}
.dlist_timetable .group:last-child {
  margin-bottom: 0;
}
.dlist_timetable dt {
  width: 120px;
  height: 23px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  margin: 0 auto 2px;
  background-color: #077C65;
  color: #fff;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0;
}
.dlist_timetable dd {
  text-align: center;
  color: #077C65;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.0625em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
}

.list_artist {
  display: flex;
  flex-wrap: wrap;
  gap: 17px 21px;
}
.list_artist > li {
  width: calc((100% - 21px) / 2);
}
.list_artist a {
  display: block;
}
.list_artist a .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 1/1;
  border-radius: 10px;
  position: relative;
}
.list_artist a .image:after {
  content: "";
  display: block;
  width: 24px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #6D2100 url(../images/ico_arrow_01_white.svg) no-repeat center/50%;
  position: absolute;
  bottom: 4px;
  right: 4px;
}
.list_artist a .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.list_artist a .name {
  margin-top: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.list_artist a .name span {
  display: block;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-size: 0.85em;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.top_parade {
  background-color: #FFFBDE;
}
.top_parade__wrap {
  background-color: #fff;
  border-radius: 20px;
  padding: 2.5em 0 3.5em;
}
.top_parade h2 {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 32px;
}
.top_parade h2 .text_01 {
  display: block;
  color: #4CA223;
  font-size: 2rem;
  letter-spacing: 0.02em;
  line-height: 1.43;
  background-image: url(../images/top_parade_01.svg), url(../images/top_parade_02.svg);
  background-repeat: no-repeat;
  background-position: top left, top right;
  background-size: auto 42px;
}
.top_parade h2 .text_02 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 309px;
  aspect-ratio: 309/40;
  background: url(../images/top_parade_03.svg) no-repeat center/contain;
  color: #fff;
  font-size: 1.0625rem;
  letter-spacing: 0;
  margin: 4px auto 0;
}
.top_parade .image_01 {
  display: block;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 24px;
}
.top_parade .para {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: 1.5em;
}
.top_parade .para p {
  margin-bottom: 1.25em;
}
.top_parade .para p:last-child {
  margin-bottom: 0;
}
.top_parade .image_02 {
  margin-bottom: 2em;
}

.dlist_parade .group {
  position: relative;
  padding: 1em 0;
  display: flex;
  align-items: center;
  gap: 12px;
}
.dlist_parade .group:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.dlist_parade .group:first-child:before {
  position: absolute;
  top: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.dlist_parade dt {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 72px;
  aspect-ratio: 72/18;
  background-color: #6D2100;
  color: #fff;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.2;
}
.dlist_parade dd {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

.top_introduce_01 {
  background-color: #FFFBDE;
  padding: 4em 0 2.5em;
}
.top_introduce_01 h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.375em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.3;
  background-image: url(../images/top_introduce_01_01.svg), url(../images/top_introduce_01_02.svg);
  background-repeat: no-repeat;
  background-position: top 9px left, top 10px right;
  background-size: 24.4px, 18.7px;
  margin-bottom: 1em;
}
.top_introduce_01 .logo {
  display: block;
  width: 100%;
  max-width: 200px;
  margin: 0 auto 2em;
}
.top_introduce_01 .para {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
  margin-bottom: 2em;
}
.top_introduce_01 .para p {
  margin-bottom: 1.25em;
}
.top_introduce_01 .para p:last-child {
  margin-bottom: 0;
}
.top_introduce_01 .list_bnr li {
  margin-bottom: 16px;
}
.top_introduce_01 .list_bnr li:last-child {
  margin-bottom: 0;
}
.top_introduce_01 .list_bnr li a {
  display: block;
}

.top_introduce_02 {
  background-color: #FFFBDE;
  padding: 2.5em 0 4.5em;
}
.top_introduce_02 h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.375em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.3;
  background-image: url(../images/top_introduce_01_01.svg), url(../images/top_introduce_01_02.svg);
  background-repeat: no-repeat;
  background-position: top 9px left, top 10px right;
  background-size: 24.4px, 18.7px;
  margin-bottom: 1em;
}
.top_introduce_02 .logo {
  display: block;
  width: 96px;
  margin: 0 auto 1.5em;
}
.top_introduce_02 .lead {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.75;
  margin-bottom: 1.5em;
}

.dlist_treehouse .group {
  margin-bottom: 2.5em;
}
.dlist_treehouse .group:last-child {
  margin-bottom: 0;
}
.dlist_treehouse dt {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.44;
  padding-bottom: 10px;
  position: relative;
  margin-bottom: 20px;
  padding-left: 1em;
}
.dlist_treehouse dt:before {
  content: "";
  display: block;
  width: 6px;
  height: 18px;
  background-color: #077C65;
  position: absolute;
  top: 5px;
  left: 0;
}
.dlist_treehouse dt:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.dlist_treehouse dd {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
}
.dlist_treehouse dd p {
  margin-bottom: 1.5em;
}
.dlist_treehouse dd p:last-child {
  margin-bottom: 0;
}
.dlist_treehouse dd .link_text {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  text-decoration: underline;
}

.treehouse_detail {
  margin: 3.5em calc(var(--sideW) * -1) 0;
  padding: 0 var(--sideW);
  overflow: hidden;
}
.treehouse_detail h3 {
  margin: 0 auto;
  width: 100%;
  max-width: 270px;
  display: flex;
  align-items: flex-start;
  gap: 5px;
}
.treehouse_detail h3:before {
  content: "";
  display: block;
  width: 5px;
  height: 58px;
  background-color: #6D2100;
}
.treehouse_detail h3 span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 260px;
  height: 40px;
  background: url(../images/treehouse_00.png) no-repeat center/contain;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.2;
}

.treehouse_slide .splide__arrow svg {
  display: none;
}
.treehouse_slide .splide__arrow--prev {
  left: -20px;
}
.treehouse_slide .splide__arrow--next {
  right: -20px;
}

.card_treehouse {
  display: block;
  border-radius: 20px;
  height: 100%;
  background-color: #F0ECCA;
  padding: 8.6% 8.6% 44px;
  position: relative;
}
.card_treehouse .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 269/202;
  border-radius: 10px;
}
.card_treehouse .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_treehouse .name {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.4;
  position: relative;
  padding: 12px 0 8px;
  margin-bottom: 8px;
}
.card_treehouse .name:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.card_treehouse .detail dt {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.3125;
  padding-left: 14px;
  position: relative;
  margin-bottom: 6px;
}
.card_treehouse .detail dt:before {
  content: "";
  display: block;
  width: 10px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #BEA297;
  position: absolute;
  top: 7px;
  left: 0;
}
.card_treehouse .detail dd {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_treehouse span {
  position: absolute;
  bottom: 12px;
  right: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.card_treehouse span:after {
  content: "";
  display: block;
  width: 24px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #6D2100 url(../images/ico_arrow_01_white.svg) no-repeat center/50%;
}

.top_access {
  background: url(../images/top_quest_01.jpg) repeat-y center top/100% auto;
  padding: 2.5em 0 3.5em;
}
.top_access h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  margin-bottom: 30px;
}
.top_access h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_access_01.svg) no-repeat center/contain;
  margin: 0 auto 4px;
}

.dlist_access {
  margin-bottom: 1.5em;
}
.dlist_access .group {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 8px;
}
.dlist_access .group:last-child {
  margin-bottom: 0;
}
.dlist_access dt {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 18px;
  background-color: #6D2100;
  color: #fff;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
}
.dlist_access dd {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

.access_gmap {
  display: block;
  overflow: hidden;
  aspect-ratio: 1/1;
}
.access_gmap iframe {
  display: block;
  width: 100%;
  height: 100%;
}

.top_news {
  background: #FFFBDE;
  padding: 2.5em 0 2.5em;
}
.top_news h2 {
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  margin-bottom: 30px;
}
.top_news h2:before {
  content: "";
  display: block;
  width: 48px;
  aspect-ratio: 48/51;
  background: url(../images/top_news_01.svg) no-repeat center/contain;
  margin: 0 auto 4px;
}
.top_news .box_white {
  background-color: #fff;
  padding: 12px 0;
  border-radius: 20px;
  margin-bottom: 32px;
}

.list_news_01 > li {
  border-bottom: 1px solid #BEA297;
  padding: 20px 0;
}
.list_news_01 > li:last-child {
  border-bottom: 0;
}

.card_news_01 {
  display: block;
}
.card_news_01 .date {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 4px;
}
.card_news_01 .ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.top_media {
  padding: 2em 0 7.1875em;
  background-color: #FFFBDE;
}
.top_media .box {
  background-color: #F0ECCA;
  border: 1px solid #CEC9A0;
  border-radius: 20px;
  padding: 36px 0 28px;
}
.top_media p {
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
  text-align: justify;
  margin-bottom: 20px;
}
.top_media dl {
  display: flex;
  align-items: center;
  gap: 24px;
}
.top_media dl:before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 144px;
  aspect-ratio: 144/96;
  background: url(../images/top_media_01.jpg) no-repeat center/cover;
  border-radius: 10px;
}
.top_media dl .group {
  flex-grow: 1;
  font-size: 0.8125em;
  letter-spacing: 0;
  line-height: 1.5;
}
.top_media dl .group dt {
  font-weight: 500;
}
.top_media dl .group dd {
  font-weight: 700;
}

.footer {
  position: relative;
  background: #6D2100 url(../images/footer_01.png) no-repeat center bottom/100%;
  color: #fff;
  padding: 3em 0;
  margin-bottom: 5em;
  position: relative;
}
.footer:before {
  content: "";
  display: block;
  width: 93px;
  aspect-ratio: 93/85;
  background: url(../images/footer_02.png) no-repeat center/contain;
  position: absolute;
  top: -65px;
  left: var(--sideW);
}
.footer .copyright {
  margin-top: 40px;
  color: #BEA297;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  text-align: center;
}

.footer_contact {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 100%;
  height: 143px;
  background-color: #9A6852;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  border-radius: 20px;
  margin-bottom: 20px;
}
.footer_contact:before {
  content: "";
  display: block;
  width: 32px;
  aspect-ratio: 32/24;
  background: url(../images/footer_04.svg) no-repeat center/contain;
  margin: 0 auto 10px;
}

.btn_to_top {
  position: absolute;
  top: -57px;
  right: var(--sideW);
  display: block;
  display: block;
  overflow: hidden;
  width: 80px;
  aspect-ratio: 1/1;
}
.btn_to_top img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.cmn_gnavi {
  max-width: var(--contentsWideS);
  margin: 0 auto;
}
.cmn_gnavi .main > li {
  border-bottom: 1px solid #9A6852;
}
.cmn_gnavi .main > li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.cmn_gnavi .main > li a:after {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_textcolor.svg) no-repeat center/50%;
}
.cmn_gnavi .sub {
  margin-top: 24px;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.cmn_gnavi .sub > li {
  margin-top: 8px;
}

.reserve_btns + .reserve_btns {
  margin-top: 40px;
}
.reserve_btns dt {
  padding-bottom: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  position: relative;
  margin-bottom: 3px;
}
.reserve_btns dt:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.reserve_btns dt span {
  display: block;
  padding-left: 18px;
  position: relative;
}
.reserve_btns dt span:before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 6px;
  aspect-ratio: 1/3;
  background-color: #077C65;
  position: absolute;
  top: 5px;
  left: 0;
}
.reserve_btns dd ul li {
  border-bottom: 1px solid #EAE4E2;
}
.reserve_btns dd ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.73;
  padding: 12px 0;
}
.reserve_btns dd ul li a:after {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #ED8D12 url(../images/ico_arrow_01_white.svg) no-repeat center/50%;
}
.reserve_btns dd ul li a.is-yet {
  pointer-events: none;
  opacity: 0.5;
}
.reserve_btns dd.is-yet {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
  margin-top: 1em;
  padding-left: 1em;
  text-indent: -1em;
}

.popup {
  position: fixed;
  z-index: -1;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: var(--contentWidePc);
  height: 100vh;
  opacity: 0;
  visibility: hidden;
}
.popup.js-active {
  opacity: 1;
  visibility: visible;
  z-index: 4;
}
.popup .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}
.popup .btn_close {
  display: block;
  width: 24px;
  aspect-ratio: 1/1;
  position: absolute;
  z-index: 3;
  top: -4px;
  right: -4px;
  overflow: hidden;
}
.popup .btn_close img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.popup .box_white {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 20px;
  width: calc(100% - var(--sideW) * 2);
}
.popup .box_white__inner {
  padding: 40px 7.38% 32px;
  max-height: 80vh;
  overflow: scroll;
}
.popup .list_kome {
  margin-top: 24px;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}

body.category .l_container,
body.single-post .l_container {
  background-image: url(../images/l_container_top.png), url(../images/top_quest_01.jpg);
  background-repeat: no-repeat, repeat-y;
  background-position: center top;
  background-size: 100% auto;
  padding: 5em 0 113px;
}

.archive .ttl_information {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 2.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 56px;
}
.archive .ttl_information:before {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 48/51;
  background: url(../images/top_news_01.svg) no-repeat center/contain;
  margin: 0 auto 4px;
}
.archive .box_white {
  padding: 12px 0;
  border-radius: 20px;
  background-color: #fff;
}

.single-post .box_white {
  padding: 32px 0 40px;
  border-radius: 20px;
  background-color: #fff;
}
.single-post .article_date {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 6px;
}
.single-post .article_ttl {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.4;
}
.single-post .post_content {
  margin-top: 16px;
  border-top: 1px solid #BEA297;
  padding-top: 32px;
}

[data-popup=treehouse],
[data-popup=artist] {
  transition: 0.3s;
  overflow: hidden;
}
[data-popup=treehouse] .inner,
[data-popup=artist] .inner {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
[data-popup=treehouse] .box,
[data-popup=artist] .box {
  width: 100%;
}
[data-popup=treehouse] .box_beige,
[data-popup=artist] .box_beige {
  background-color: #F0ECCA;
  border-radius: 20px;
}
[data-popup=treehouse] .box_beige__inner,
[data-popup=artist] .box_beige__inner {
  padding-top: 28px;
  padding-bottom: 40px;
  padding: 20px 6.15% 40px;
  max-height: 80vh;
  overflow: scroll;
  overscroll-behavior: contain;
}
[data-popup=treehouse] .box_white,
[data-popup=artist] .box_white {
  background-color: #fff;
  border-radius: 20px;
  width: 100%;
}
[data-popup=treehouse] .box_white__inner,
[data-popup=artist] .box_white__inner {
  padding: 20px 6.15% 40px;
  max-height: 80vh;
  overflow: scroll;
  overscroll-behavior: contain;
}
[data-popup=treehouse] .btn_close,
[data-popup=artist] .btn_close {
  top: 12px;
  right: 12px;
}

.treehouse_popup_slider .splide__arrow--prev,
.artist_popup_slider .splide__arrow--prev {
  left: -20px;
}
.treehouse_popup_slider .splide__arrow--next,
.artist_popup_slider .splide__arrow--next {
  right: -20px;
}

.card_treehouse_popup {
  position: relative;
}
.card_treehouse_popup .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 269/202;
  border-radius: 10px;
}
.card_treehouse_popup .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_treehouse_popup .name {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.4;
  position: relative;
  padding: 12px 0 8px;
  margin-bottom: 8px;
}
.card_treehouse_popup .name:after {
  position: absolute;
  bottom: -1px;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: radial-gradient(circle, #b79a8c 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left center;
}
.card_treehouse_popup .detail dt {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.3125;
  padding-left: 14px;
  position: relative;
  margin-bottom: 6px;
}
.card_treehouse_popup .detail dt:before {
  content: "";
  display: block;
  width: 10px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #BEA297;
  position: absolute;
  top: 7px;
  left: 0;
}
.card_treehouse_popup .detail dd {
  font-size: 0.875em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_treehouse_popup .para {
  margin-top: 20px;
}
.card_treehouse_popup .para p {
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
}
.card_treehouse_popup .para p + p {
  margin-top: 1.75em;
}

.card_artist_popup .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 1/1;
  border-radius: 10px;
}
.card_artist_popup .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_artist_popup .name {
  margin-top: 12px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.25em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.card_artist_popup .name span {
  display: block;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.card_artist_popup .para {
  margin-top: 12px;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.75;
}
.card_artist_popup .links {
  margin-top: 10px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.card_artist_popup .links .music {
  margin-bottom: 2px;
}
.card_artist_popup .links .music a {
  text-decoration: underline;
}
.card_artist_popup .links .instagram {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1.5;
  padding-left: 24px;
  position: relative;
}
.card_artist_popup .links .instagram:before {
  position: absolute;
  top: 3px;
  left: 0;
  flex-shrink: 0;
  content: "";
  display: block;
  width: 16px;
  aspect-ratio: 1/1;
  background: url(../images/ico_instagram_textcolor.svg) no-repeat center/contain;
  margin-right: 8px;
}
.card_artist_popup .links .instagram span {
  margin-left: 4px;
  font-weight: 500;
  letter-spacing: 0;
  text-decoration: underline;
}
.card_artist_popup .links .instagram + .instagram {
  margin-top: 0.3em;
}
.card_artist_popup .movie {
  background-color: #FFFBDE;
  padding: 24px 4.2%;
  margin-top: 24px;
}
.card_artist_popup .movie p {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.44;
  text-align: center;
  margin-bottom: 16px;
}
.card_artist_popup .movie p span {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 0 25px;
  background-image: url(../images/artist_movie_01.svg), url(../images/artist_movie_02.svg);
  background-repeat: no-repeat;
  background-position: center left, center right;
  background-size: 10px;
}
.card_artist_popup .movie .iframe {
  display: block;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.card_artist_popup .movie .iframe iframe {
  display: block;
  width: 100%;
  height: 100%;
}
.card_artist_popup .movie .caption {
  text-align: center;
  font-size: 0.8125em;
  font-weight: 500;
  line-height: 1.8;
}

.popup.shops .inner {
  height: 100vh;
  overflow: scroll;
  padding-top: 100px;
  padding-bottom: 100px;
}
.popup.shops .shop_contents {
  position: relative;
  z-index: 1;
}
.popup.shops .btn_close {
  right: var(--sideW);
  top: 46px;
}

.label_area {
  background: #6D2100;
  color: #fff;
  text-align: center;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  padding: 4px 0;
  border-radius: 50px;
}
.label_area.shop_area-21 {
  background: #00718E;
}
.label_area.shop_area-20 {
  background: #E47400;
}
.label_area.shop_area-19 {
  background: #007B40;
}
.label_area.shop_area-18 {
  background: #988B25;
}
.label_area.shop_area-17 {
  background: #00A3CF;
}
.label_area.shop_area-16 {
  background: #8F3C2B;
}

.list_shop {
  margin-top: 2em;
}
.list_shop > li {
  margin-bottom: 20px;
}
.list_shop > li:last-child {
  margin-bottom: 0;
}

.card_shop {
  background-color: #fff;
  border-radius: 20px;
  padding: 20px 5.3%;
}
.card_shop .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 285/134;
  border-radius: 10px;
  position: relative;
  margin-bottom: 16px;
}
.card_shop .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.card_shop .image .cat {
  position: absolute;
  top: 8px;
  left: 8px;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 8px;
  border-radius: 2px;
  font-size: 0.8125em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.615;
  background-color: #6D2100;
  color: #fff;
}
.card_shop .image .cat.shop_cat-15 {
  background-color: #FCF200;
  color: #6D2100;
}
.card_shop .image .cat.shop_cat-14 {
  background-color: #C50018;
  color: #fff;
}
.card_shop .image .label {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 8px;
  background-color: #232584;
  color: #FCF200;
  border-radius: 2px;
  font-size: 0.8125em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 21px;
  position: absolute;
  top: 32px;
  left: 8px;
}
.card_shop .image .label.skyblue {
  background-color: #009FE6;
}
.card_shop .name {
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.8125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  padding-left: 14px;
  position: relative;
}
.card_shop .name:before {
  content: "";
  display: block;
  width: 9px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #BEA297;
  position: absolute;
  top: 5px;
  left: 0;
}
.card_shop .menu {
  margin-top: 2px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 1.125em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.45;
}
.card_shop .description {
  margin-top: 10px;
  font-size: 0.8125em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_shop .dlist_shop {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-top: 16px;
}
.card_shop .dlist_shop dt {
  flex-shrink: 0;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 8px;
  background-color: #6D2100;
  color: #fff;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_shop .dlist_shop dd {
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_shop .dlist_shop + .dlist_shop {
  margin-top: 4px;
}
.card_shop .instagram {
  margin-top: 12px;
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  gap: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_shop .instagram:before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  background: url(../images/ico_instagram_textcolor.svg) no-repeat center/contain;
}
.card_shop .instagram + .website {
  margin-top: 4px;
}
.card_shop .website {
  margin-top: 12px;
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  gap: 8px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.5;
}
.card_shop .website:before {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  background: url(../images/ico_website_textcolor.svg) no-repeat center/contain;
}
.card_shop .form {
  margin-top: 20px;
  display: flex;
  align-items: center;
  width: 100%;
  height: 3em;
  padding: 0 8.88%;
  background-color: #ED8D12;
  border-radius: 50px;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  position: relative;
}
.card_shop .form:after {
  content: "";
  display: block;
  width: 1.75em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_01_orange.svg) no-repeat center/50%;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}

.area_announce {
  background-color: #FFFBDE;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.875em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  padding: 0.75em 5.3%;
  margin-top: 24px;
}

.access_announce {
  background-color: #FFFBDE;
  color: #6D2100;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 0.9375em;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.5;
  padding: 1em 5.3%;
  margin: 24px 0;
}