@charset "UTF-8";
@import "reset.css";

/* font set */
body {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 3.6232vw;
  font-feature-settings: "palt";
}
._san {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
._txt_ns {
  font-family: "Noto Serif Display", serif;
  font-weight: 400;
}
._wt_l { font-weight: 300; }
._wt_r { font-weight: 400; }

/* color set */
body {
  --color-bg: rgb(13,18,22);
  --color-bg2: rgb(13,31,22);
  --color-bg3: rgb(30,29,25);
  --color-txt: rgb(196,188,177);
  --color-op: rgb(255,219,124);
  --color-op-b: rgba(255,219,124,.5);
  --color-op2: rgb(255,128,73);
  --color-op2-b: rgba(255,128,73,.5);
  --color-op3: rgb(228,129,156);
  --color-op3-b: rgba(228,129,156,.5);
  --color-black: rgb(0,0,0);
  --color-white: rgb(255,255,255);
}
._f50 { font-size: calc(50 / 30 * 100%);}
._f43 { font-size: calc(43 / 30 * 100%);}
._f39 { font-size: calc(39 / 30 * 100%);}
._f35 { font-size: calc(35 / 30 * 100%);}
._f33 { font-size: calc(33 / 30 * 100%);}
._f30 { font-size: calc(30 / 30 * 100%);}
._f29 { font-size: calc(29 / 30 * 100%);}
._f26 { font-size: calc(26 / 30 * 100%);}
._f23 { font-size: calc(23 / 30 * 100%);}

/* tool */
.bgt {
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
._txt_c {
  text-align: center;
}
._nols {
  letter-spacing: 0 !important;
}
._ls01 {
  letter-spacing: .1em !important;
}

._idt_125 {
  text-indent: -1.25em;
  padding-left: 1.25em;
}
._idt_100 {
  text-indent: -1em;
  padding-left: 1em;
}
._mt_1em {
  margin-top: 1em;
}

img {
  width: 100%;
  height: auto;
}

/* layout */
body {
  --mt160: calc(160 / 828 * 100%);
  --mt120: calc(120 / 828 * 100%);
  --mt90:  calc(90 / 828 * 100%);
  --mt72:  calc(72 / 828 * 100%);
  --mt45:  calc(45 / 670 * 100%);
  --mt25:  calc(25 / 670 * 100%);

  --pcmr-1600: (480 / 1600 * 100%);
  --pcmr-769: (39.7112vw - 155.3791px); /* 150 -> 480 */

  background-color: var(--color-bg);
  color: var(--color-txt);
  line-height: 1.5484;
}
.sp_wrap {
  position: relative;
  background-color: var(--color-bg);
  z-index: 100;
}
.sp_wrap .sp_inner {
  overflow: hidden;
}
.sp_wrap .loading {
  display: none;
}
.sp_wrap._loading .sp_inner {
  height: 100dvh;
}
.sp_wrap._loading .loading {
  display: flex;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 900;
  width: 100%;
  height: 100%;
  padding-top: 30dvh;
  background-color: var(--color-bg);
  opacity: 1;
  transition: opacity .5s .6s;
}
.sp_wrap._loading .loading._start {
  opacity: 0;
}
.pc_wrap {
  display: none;
  background-color: var(--color-bg);
  transition: background-color .3s ease;
}

@media screen and (min-width: 1600px) {
  body {
    font-size: 1.3125vw;
  }
  .sp_wrap {
    width: calc(580 / 1600 * 100%);
    margin-right: calc(var(--pcmr-1600));
    margin-left: auto;
  }
  .pc_wrap .pc_logo {
    top: 3.75vw;
    right: 4.5vw;
    width: 7.5vw;
    aspect-ratio: 3/14;
  }
  .pc_wrap .nav {
    left: 6.25vw;
  }
  .pc_wrap .slider_box {
    right: calc(var(--pcmr-1600) - 3.125vw);
  }
}
@media screen and (min-width: 769px) {
  body {
    font-size: calc(0.6017vw + 11.373px);
  }
  .sp_wrap {
    width: calc(16.8472vw + 310.4452px); /* 440 -> 580 */
    margin-right: calc(var(--pcmr-769));
    margin-left: auto;
  }
  .sp_wrap::before,
  .sp_wrap::after {
    content: '';
    position: absolute;
    top: 0;
    width: 1px;
    height: 100%;
    opacity: .5;
    background-color: var(--color-white);
  }
  .sp_wrap::before {
    left: -1px;
  }
  .sp_wrap::after {
    right: -1px;
  }
  .sp_wrap._loading {
    height: calc(100dvh + 1px);
  }
  .pc_wrap {
    display: block;
    position: fixed;
    z-index: 50;
    top: 0;
    left: 0;
    width: 100%;
    height: 100dvh;
  }
  .pc_wrap .pc_logo {
    position: absolute;
    top: 3.75vw;
    right: 4.5vw;
    width: 7.5vw;
    aspect-ratio: 3/14;
    background-size: contain;
    background-position: center center;
    background-image: url(../images/title_pc.svg);
  }
  .pc_wrap .nav {
    position: absolute;
    bottom: calc(9.976vw - 44.6154px);
    left: calc(9.0144vw - 44.2308px);
    font-size: 2.0625vw;
    color: var(--color-text);
  }
  .pc_wrap .nav .ttl {
    width: 100%;
    aspect-ratio: 218/36;
    margin-bottom: 1.25em;
    background-image: url(../images/txt_place_pc.svg);
  }
  .pc_wrap .nav ul {
    display: flex;
    flex-direction: column;
    gap: 2.0625vw;
  }
  .pc_wrap .nav ul li a {
    display: block;
  }
  .pc_wrap.south .nav ul li:nth-child(1) a span {
    text-decoration: underline;
    color: var(--color-op);
  }
  .pc_wrap.north .nav ul li:nth-child(2) a span {
    text-decoration: underline;
    color: var(--color-op2);
  }
  .pc_wrap.park .nav ul li:nth-child(3) a span {
    text-decoration: underline;
    color: var(--color-op3);
  }
  .pc_wrap .slider_box {
    position: absolute;
    top: 0;
    right: calc(var(--pcmr-769) - 3.125vw);
    width: 5px;
    height: 100dvh;
  }
  .pc_wrap .slider_box .slider {
    position: absolute;
    top: 27.4%;
    left: 0;
    width: 5px;
    height: 64%;
    border-radius: 3px;
    background-color: var(--color-white);
  }
  .pc_wrap .slider_box .slider .slider_handle {
    display: block;
    position: absolute;
    top: 0;
    left: -5px;
    width: 15px;
    height: calc(56.8 / 640 * 100%);
    cursor: pointer;
  }
  .pc_wrap .slider_box .slider .slider_handle .slider_v {
    position: absolute;
    top: 0;
    left: 5px;
    width: 5px;
    height: 100%;
    border-radius: 3px;
    background-color: var(--color-op);
  }
  .pc_bg {
    display: block;
    position: fixed;
    z-index: 40;
    top: 0;
    left: 0;
    width: 100%;
    height: 100dvh;
  }
  .pc_bg::before, .pc_bg::after {
    content: '';
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
  }
  .pc_bg::before {
    top: 0;
    left: 0;
    width: 29.125vw;
    aspect-ratio: 466/456;
    background-image: url(../images/pc_bg01.svg);
  }
  .pc_bg::after {
    bottom: 0;
    right: 0;
    width: 29.875vw;
    aspect-ratio: 478/620;
    background-image: url(../images/pc_bg02.svg);
  }
}

.row_box > li {
  display: flex;
  align-items: baseline;
  column-gap: 1em;
}
.row_box._type2 > li,
.row_box._type3 > li {
  column-gap: 0;
}
.row_box._type3 > li {
  flex-wrap: wrap;
}
.row_box > li > * {
  display: block;
}
.row_box._type3 > li > * {
  width: 100%;
}
.row_box > li > *:nth-child(2) {
  flex: 1 0;
}
.row_box._type2 > li > *:nth-child(2) {
  padding-left: 1em;
  text-indent: -1em;
}
.row_box._type3 > li > *:nth-child(2) {
  padding-left: 2em;
}



/* header*/
.header {
  position: relative;
  width: 100%;
  height: 100svh;
  background-color: var(--color-bg);
}
.header .title {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(712 / 828 * 100%);
  height: calc(1210 / 1354 * 100%);
  transform: translate(-50%, -50%);
  z-index: 20;
}
.header .title_txt {
  position: absolute;
  top: 0;
}
.header .txt1 {
  right: 0;
  width: calc(116 / 712 * 100%);
  aspect-ratio: 116/570;
}
.header .txt2 {
  left: 0;
  height: 100%;
  aspect-ratio: 88/1210;
}
.header .title_txt span {
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.header .txt1 span {
  width: 50%;
  aspect-ratio: 1/1;
  opacity: 0;
  transition-duration: .5s;
  transition-property: opacity;
}
._st .header .txt1 span {
  opacity: 1;
}
.header .txt1 span:nth-child(1)  { top: 0; right: 0; background-image: url(../images/txt1-1.svg);}
.header .txt1 span:nth-child(2)  { top: 0; right: 0; background-image: url(../images/txt1-2.svg);}
.header .txt1 span:nth-child(3)  { top: 0; right: 0; background-image: url(../images/txt1-3.svg);}
.header .txt1 span:nth-child(4)  { top: 0; right: 0; background-image: url(../images/txt1-4.svg);}
.header .txt1 span:nth-child(5)  { top: 0; right: 0; background-image: url(../images/txt1-5.svg);}
.header .txt1 span:nth-child(6)  { bottom: 0; left: 0; background-image: url(../images/txt1-6.svg);}
.header .txt1 span:nth-child(7)  { bottom: 0; left: 0; background-image: url(../images/txt1-7.svg);}
.header .txt1 span:nth-child(8)  { bottom: 0; left: 0; background-image: url(../images/txt1-8.svg);}
.header .txt1 span:nth-child(9)  { bottom: 0; left: 0; background-image: url(../images/txt1-9.svg);}
.header .txt1 span:nth-child(10) { bottom: 0; left: 0; background-image: url(../images/txt1-10.svg);}
.header .txt1 span:nth-child(11) { bottom: 0; left: 0; background-image: url(../images/txt1-11.svg);}
.header .txt1 span:nth-child(12) { bottom: 0; left: 0; background-image: url(../images/txt1-12.svg);}

.header .txt1 span:nth-child(1)  { transition-delay: 0.2s; transform: translate(0, 0);}
.header .txt1 span:nth-child(2)  { transition-delay: 0.2s; transform: translate(0, 100%);}
.header .txt1 span:nth-child(3)  { transition-delay: 0.2s; transform: translate(0, 200%);}
.header .txt1 span:nth-child(4)  { transition-delay: 0.2s; transform: translate(0, 300%);}
.header .txt1 span:nth-child(5)  { transition-delay: 0.2s; transform: translate(0, 400%);}
.header .txt1 span:nth-child(6)  { transition-delay: 0.2s; transform: translate(0, -600%);}
.header .txt1 span:nth-child(7)  { transition-delay: 0.2s; transform: translate(0, -500%);}
.header .txt1 span:nth-child(8)  { transition-delay: 0.2s; transform: translate(0, -400%);}
.header .txt1 span:nth-child(9)  { transition-delay: 0.2s; transform: translate(0, -300%);}
.header .txt1 span:nth-child(10) { transition-delay: 0.2s; transform: translate(0, -200%);}
.header .txt1 span:nth-child(11) { transition-delay: 0.2s; transform: translate(0, -100%);}
.header .txt1 span:nth-child(12) { transition-delay: 0.2s; transform: translate(0, 0);}

.header .txt2 span {
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  transition-duration: .5s;
  transition-property: opacity, filter;
}
.header .txt2 span:nth-child(-n+8) {
  transition-duration: .8s;
  filter: blur(5px);
}
._st .header .txt2 span {
  opacity: 1;
}
._st .header .txt2 span:nth-child(-n+8) {
  filter: blur(0px);
}
.header .txt2 span:nth-child(1)  { aspect-ratio: 1/1; background-image: url(../images/txt2-1.svg); }
.header .txt2 span:nth-child(2)  { aspect-ratio: 1/1; background-image: url(../images/txt2-2.svg); }
.header .txt2 span:nth-child(3)  { aspect-ratio: 88/110; background-image: url(../images/txt2-3.svg); }
.header .txt2 span:nth-child(4)  { aspect-ratio: 1/1; background-image: url(../images/txt2-4.svg); }
.header .txt2 span:nth-child(5)  { aspect-ratio: 1/1; background-image: url(../images/txt2-5.svg); }
.header .txt2 span:nth-child(6)  { aspect-ratio: 88/74; background-image: url(../images/txt2-6.svg); }
.header .txt2 span:nth-child(7)  { aspect-ratio: 88/78; background-image: url(../images/txt2-7.svg); }
.header .txt2 span:nth-child(8)  { aspect-ratio: 88/74; background-image: url(../images/txt2-8.svg); }
.header .txt2 span:nth-child(9)  { aspect-ratio: 88/76; background-image: url(../images/txt2-9.svg); }
.header .txt2 span:nth-child(10) { aspect-ratio: 88/76; background-image: url(../images/txt2-10.svg); }
.header .txt2 span:nth-child(11) { aspect-ratio: 88/76; background-image: url(../images/txt2-11.svg); }
.header .txt2 span:nth-child(12) { aspect-ratio: 88/76; background-image: url(../images/txt2-12.svg); }

.header .txt2 span:nth-child(1)  { transition-delay: 0.2s; top: 0;}
.header .txt2 span:nth-child(2)  { transition-delay: 0.21s; top: calc(136 / 1210 * 100%);}
.header .txt2 span:nth-child(3)  { transition-delay: 0.22s; top: calc(224 / 1210 * 100%);}
.header .txt2 span:nth-child(4)  { transition-delay: 0.23s; top: calc(334 / 1210 * 100%);}
.header .txt2 span:nth-child(5)  { transition-delay: 0.24s; top: calc(470 / 1210 * 100%);}
.header .txt2 span:nth-child(6)  { transition-delay: 0.25s; top: calc(594 / 1210 * 100%);}
.header .txt2 span:nth-child(7)  { transition-delay: 0.26s; top: calc(698 / 1210 * 100%);}
.header .txt2 span:nth-child(8)  { transition-delay: 0.27s; top: calc(806 / 1210 * 100%);}
.header .txt2 span:nth-child(9)  { transition-delay: 0.3s; top: calc(906 / 1210 * 100%);}
.header .txt2 span:nth-child(10) { transition-delay: 0.3s; top: calc(982 / 1210 * 100%);}
.header .txt2 span:nth-child(11) { transition-delay: 0.3s; top: calc(1058 / 1210 * 100%);}
.header .txt2 span:nth-child(12) { transition-delay: 0.3s; top: calc(1134 / 1210 * 100%);}

.header .txt2::before, .header .txt2::after {
  content: '';
  position: absolute;
  top: 0;
  width: 1px;
  height: 0;
  background-color: var(--color-white);
  opacity: 0;
  transition-duration: 0.5s;
  transition-property: height, opacity;
  transition-timing-function: ease-out;
}
.header .txt2::before {
  left: 0;
  transition-delay: 0.25s;
}
.header .txt2::after {
  right: 0;
  transition-delay: 0.28s;
}
._st .header .txt2::before {
  height: calc(890 / 1210 * 100%);
  opacity: 1;
}
._st .header .txt2::after {
  height: calc(882 / 1210 * 100%);
  opacity: 1;
}

.header .mv {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 10;
}
.header .mv .mv01, .header .mv .mv02 {
  position: absolute;
  left: 0;
  width: 100%;
  height: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  opacity: 0;
  /* filter: blur(20px);*/
  transition-duration: .8s;
  transition-property: opacity, filter, transform;
  transition-timing-function: ease-out;
}
.header .mv .mv01 {
  top: 0;
  background-image: url(../images/mv01.webp);
  transform: translate(20%, 0);
  transition-delay: 0.6s;
}
.header .mv .mv02 {
  bottom: 0;
  background-image: url(../images/mv02.webp);
  transform: translate(-20%, 0);
  transition-delay: 0.7s;
}
._st .header .mv .mv01, ._st .header .mv .mv02 {
  opacity: 1;
  filter: blur(0px);
  transform: translate(0, 0);
}


/* footer*/
.footer {
  padding-top: calc(120 / 828 * 100%);
  background-color: var(--color-white);
  color: var(--color-black);
}
.footer .l-container {
  padding: 0 1.6rem;
}
.footer .siteFooter__upper {
  display: flex;
  flex-direction: column-reverse;
}
.footer .siteFooter__brandHeader {
  margin-bottom: 1.5rem;
  font-family: "Jost",sans-serif;
  font-size: calc(14 / 16 * 100%);
  font-weight: 500;
  text-align: center;
}
.footer .siteFooter__brandList {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
}
.footer .siteFooter__brandList > a {
  display: block;
  margin-left: -1em;
  max-width: 40%;
}
.footer .siteFooter__logowrap {
  margin: 2.5rem 0 0;
  width: 100%;
  text-align: center;
  padding: 1.5rem 0 0;
  border-top: 0.1rem solid #E3E3E3;
}
.footer .siteFooter__logolink {
  display: block;
  margin: 0 auto;
  max-width: 235px;
}
.footer .siteFooter__companyInfo {
  margin-top: 1rem;
  font-size: calc(12 / 16 * 100%);
}
.footer .siteFooter__copyright {
  margin-top: 2.5rem;
  padding: 0.8rem 0;
  background-color: #000;
  color: #fff;
  font-size: calc(12 / 16 * 100%);
  line-height: 1.5;
  text-align: center;
}

/* main */
.main {
  margin-top: var(--mt120);
}
.main .lead {
  text-align: center;
  line-height: 2.3636;
  letter-spacing: .2em;
}
.main .note {
  padding: 0 calc(64 / 828 * 100%) var(--mt120);
  background-color: var(--color-bg3);
  color: var(--color-white);
}
.main .note ul li {
  text-indent: -1.25em;
  padding-left: 1.25em;
}

/* nav_box */
.main .nav_box {
  margin-top: var(--mt120);
}
.main .nav_box > .ttl {
  width: 100%;
  aspect-ratio: 828/34;
  background-image: url(../images/txt_place.svg);
}
.main .nav_box > ul {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: calc(45 / 828 * 100%);
  line-height: calc(45 / 35);
  gap: 1px;
}
.main .nav_box > ul > li {
  position: relative;
  padding: 0 calc(45 / 828 * 100%);
}
.main .nav_box > ul > li:nth-child(n+2)::before {
  content: '';
  position: absolute;
  top: 0;
  left: -1px;
  width: 1px;
  height: 100%;
  background-color: var(--color-txt);
  opacity: .5;
}


/* section */
.sec_header {
  margin-top: var(--mt120);
  text-align: center;
}
.sec_south .sec_header { color: var(--color-op);}
.sec_north .sec_header { color: var(--color-op2);}
.sec_park .sec_header { color: var(--color-op3);}
.sec_header h2 {
  letter-spacing: .25em;
}

.sec_north, .sec_park {
  margin-top: calc(580 / 828 * 100%);
}
.sec_south, .sec_north, .sec_park {
  position: relative;
  padding-top: 1px;
}
.sec_south { background-color: var(--color-bg); }
.sec_north { background-color: var(--color-bg2); }
.sec_park  { background-color: var(--color-bg3); }
.sec_north::before, .sec_park::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: calc(580 / 828 * 100%);
  transform: translate(0, -100%);
  background-repeat: no-repeat;
  background-size: contain;
  opacity: .6;
}
.sec_north::before { background-image: url(../images/img01.webp);}
.sec_park::before  { background-image: url(../images/img02.webp);}

.sec_south .ttl { color: var(--color-op);}
.sec_north .ttl { color: var(--color-op2);}
.sec_park  .ttl { color: var(--color-op3);}

.sec_body {
  padding-bottom: var(--mt160);
}

/* shop_info_box */
.shop_info_box {
  margin-top: var(--mt120);
}
.shop_info_box:first-child {
  margin-top: var(--mt72);
}
.shop_info_box .bg {
  position: relative;
}
.shop_info_box .bg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 828/1250;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  background-image: url(../images/shop_info_bg.svg);
}
.sec_south .shop_info_box:nth-child(2n) .bg::before {
  transform: scale(-1, 1);
}
.sec_north .shop_info_box:nth-child(2n+1) .bg::before {
  transform: scale(-1, 1);
}

.shop_images {
  position: relative;
  width: calc(750 / 828 * 100%);
  aspect-ratio: 75/62;
  margin-top: calc(45 / 828 * 100%);
  margin-right: auto;
  margin-left: auto;
  overflow: visible;
}
.shop_images .swiper {
  width: 100%;
  aspect-ratio: 75/62;
  overflow: visible;
}
.shop_images .swiper-slide {
  position: relative;
  mask-image: url(../images/mask01.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
}
.sec_south .shop_images .swiper-slide { background-color: var(--color-op); }
.sec_north .shop_images .swiper-slide { background-color: var(--color-op2); }
.sec_park .shop_images .swiper-slide { background-color: var(--color-op3); }

.shop_images .swiper-slide .img {
  display: block;
  width: 100%;
  aspect-ratio: 75/62;
  mask-image: url(../images/mask01i.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  background-color: var(--color-black);
  overflow: hidden;
}
.shop_images .swiper-slide .img img {
  margin-top: calc(((595 - 720) / 2) / 720 * 100%);
}
.shop_images .swiper-button-next,
.shop_images .swiper-button-prev {
  width: calc(75 / 750 * 100%);
  height: calc(75 / 620 * 100%);
  border-radius: 50%;
  border-width: 1px;
  border-style: solid;
  background-repeat: no-repeat;
  background-size: contain;
}
.sec_south .shop_images .swiper-button-next,
.sec_south .shop_images .swiper-button-prev {
  border-color: var(--color-op-b);
  background-color: var(--color-bg);
  background-image: url(../images/icon_arrow01.svg);
}
.sec_north .shop_images .swiper-button-next,
.sec_north .shop_images .swiper-button-prev {
  border-color: var(--color-op2-b);
  background-color: var(--color-bg2);
  background-image: url(../images/icon_arrow02.svg);
}
.sec_park .shop_images .swiper-button-next,
.sec_park .shop_images .swiper-button-prev {
  border-color: var(--color-op3-b);
  background-color: var(--color-bg3);
  background-image: url(../images/icon_arrow03.svg);
}
.shop_images .swiper-button-next {
  right: 0;
  transform: translate(25%, 0) scale(-1, 1);
  transition: transform .2s ease-out;
}
.shop_images .swiper-button-next:hover {
  transform: translate(50%, 0) scale(-1, 1);
}
.shop_images .swiper-button-prev {
  left: 0;
  transform: translate(-25%, 0);
  transition: transform .2s ease-out;
}
.shop_images .swiper-button-prev:hover {
  transform: translate(-50%, 0);
}
.shop_images .swiper-button-next svg,
.shop_images .swiper-button-prev svg {
  display: none;
}

.shop_name_box {
  text-align: center;
}
.shop_name_box .shop_name {
  letter-spacing: .15em;
}
.shop_name_box .shop_place {
  margin-top: calc(25 / 828 * 100%);
}

.shop_info {
  position: relative;
  width: calc(670 / 828 * 100% + 2px);
  margin-top: var(--mt90);
  margin-right: auto;
  margin-left: auto;
  border-width: 1px;
  border-style: solid;
}
.sec_south .shop_info { border-color: var(--color-op-b);  background-color: var(--color-bg);}
.sec_north .shop_info { border-color: var(--color-op2-b); background-color: var(--color-bg2);}
.sec_park  .shop_info { border-color: var(--color-op3-b); background-color: var(--color-bg3);}

.shop_info .ttl_box {
  position: relative;
}
.shop_info .ttl_box::after {
  content: '';
  position: absolute;
  top: calc(14 / 48 * 100%);
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
}
.sec_south .shop_info .ttl_box::after { background-image: url(../images/txt_special01.svg); }
.sec_north .shop_info .ttl_box::after { background-image: url(../images/txt_special02.svg); }
.sec_park  .shop_info .ttl_box::after { background-image: url(../images/txt_special03.svg?ud=25120801); }
.shop_info .ttl_box .ttl {
  position: relative;
  aspect-ratio: 670/48;
  margin-top: 0 !important;
  border-bottom-width: 1px;
  border-bottom-style: solid;
}
.sec_south .shop_info .ttl_box .ttl { border-bottom-color: var(--color-op-b);}
.sec_north .shop_info .ttl_box .ttl { border-bottom-color: var(--color-op2-b);}
.sec_park  .shop_info .ttl_box .ttl { border-bottom-color: var(--color-op3-b);}

.shop_info .course_name {
  margin-top: var(--mt45);
  text-align: center;
}
.shop_info > div > .ttl {
  margin-top: var(--mt45);
  margin-bottom: var(--mt25);
  padding-left: 0.75em;
  line-height: 1;
  letter-spacing: .2em;
}
.shop_info > div > .text {
  padding-left: 1.25em;
  padding-right: 1.25em;
  letter-spacing: -.045em;
}
.shop_info > div > .price {
  margin-top: var(--mt45);
  text-align: center;
  letter-spacing: 0em;
}
.shop_info > div > .row {
  display: flex;
  letter-spacing: 0em;
}
.shop_info > div > .row > *:first-child {
  width: 3.5em;
}
.shop_info > div > .row._type2 {
  padding-right: 0;
}
.shop_info > div > .row._type2 > *:first-child {
  width: 10.5em;
}
.shop_info > div > .row._type3 > *:first-child {
  width: 7.5em;
}
.shop_info > div > .row.tel a {
  letter-spacing: .1em;
}
.shop_info .reserve {
  margin-top: calc(80 / 670 * 100%);
  margin-bottom: var(--mt45);
}
.shop_info .link_web {
  text-decoration: underline;
}
.shop_info .notice {
  margin-bottom: var(--mt45);
}

/* parts */
/* btn_page_top */
.btn_page_top {
  display: block;
  position: fixed;
  bottom: 12px;
  right: 6px;
  opacity: 0;
  transition: opacity .5s ease-out;
  z-index: 100;
}
.btn_page_top._show {
  opacity: 1;
}
.btn_page_top .btn {
  display: block;
  width: 38px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: var(--color-op);
  background-image: url(../images/icon_arrow04.svg);
}
@media screen and (min-width: 1600px) {
  .btn_page_top {
    right: calc(6px + var(--pcmr-1600));
  }
}
@media screen and (min-width: 769px) {
  .btn_page_top {
    right: calc(6px + var(--pcmr-769));
  }
}




/*********************************
 Cookie banner
**********************************/
.cookie__banner {
  position: fixed;
  bottom: 20px;
  left: 20px;
  z-index: 99;
  background: #fff;
  max-width: 420px;
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid #b3d99c;
  transition: all 0.8s ease;
  opacity: 0;
  visibility: hidden;
  font-size: 14px;
}
@media only screen and (max-width: 768px) {
  .cookie__banner {
    left: 16px;
    right: 16px;
    bottom: 16px;
    margin: auto;
  }
}

.cookie__banner.is-active {
  transition: all 0.8s ease;
  opacity: 1;
  visibility: visible;
  z-index: 100;
}

.cookie__inner {
  padding: 22px 19px;
  color: var(--color-black);
}
@media only screen and (max-width: 768px) {
  .cookie__inner {
    padding: 20px 15px 25px;
  }
}

.cookie__text {
  line-height: 1.75;
  letter-spacing: 0;
}
@media only screen and (max-width: 768px) {
  .cookie__text {
    font-size: 12px;
    line-height: 1.45;
  }
}

.cookie__link {
  color: #000;
  text-decoration: underline;
}
@media only screen and (min-width: 769px) {
  .cookie__link:hover {
    text-decoration: none;
  }
}

.cookie__btns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}
@media only screen and (max-width: 768px) {
  .cookie__btns {
    gap: 20px;
  }
}

.cookie__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 184px;
  width: 100%;
  height: 46px;
  text-decoration: underline;
  border-radius: 23px;
  border: 1px solid transparent;
  text-align: center;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.5s ease;
}
@media only screen and (min-width: 769px) {
  .cookie__btn:hover {
    border: 1px solid #b3d99c;
    background: linear-gradient(90deg, #fd0 0%, #b3d99c 100%);
    text-decoration: none;
    transition: all 0.5s ease;
  }
}

@media only screen and (max-width: 768px) {
  .cookie__btn.cookie__btn-agree {
    border: 1px solid #b3d99c;
    text-decoration: none;
  }
}




/*
 -- Animations --
*/
._f_in_bt {
  position: relative;
  top: 15dvh;
  opacity: 0;
  transition:
    top .8s,
    opacity 1.2s;
}
._f_in_bt._delay02 {
  transition:
    top .8s .2s,
    opacity 1.2s .2s;
}
._f_in_bt._start {
  opacity: 1;
  top: 0;
}
._s_in_tb {
  position: relative;
}
._s_in_tb::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: height 1.5s;
}
.sec_south ._s_in_tb::after { background-color: var(--color-bg); }
.sec_north ._s_in_tb::after { background-color: var(--color-bg2); }
.sec_park  ._s_in_tb::after { background-color: var(--color-bg3); }

._s_in_tb._start::after {
  height: 0;
}

.pc_wrap .pc_logo {
  filter: blur(10px);
  opacity: 0;
  transition:
    opacity .3s 1.1s,
    filter .3s 1.1s;
}
.pc_wrap._st .pc_logo {
  filter: blur(0px);
  opacity: 1;
}

.loader,
.loader:before,
.loader:after {
  background: var(--color-yellow);
  animation: load1 1s infinite ease-in-out;
  width: .5em;
  height: 4em;
}
.loader {
  color: var(--color-yellow);
  text-indent: -9999em;
  margin: 88px auto;
  position: relative;
  font-size: 11px;
  transform: translateZ(0);
  animation-delay: -0.16s;
  opacity: 1;
  transition: opacity .2s;
}
.loading._start .loader {
  opacity: 0;
}
.loader:before,
.loader:after {
  position: absolute;
  top: 0;
  content: '';
}
.loader:before {
  left: -1.2em;
  animation-delay: -0.32s;
}
.loader:after {
  left: 1.2em;
}

@keyframes load1 {
  0%,
  80%,
  100% {
    box-shadow: 0 0;
    height: 4em;
  }
  40% {
    box-shadow: 0 -2em;
    height: 5em;
  }
}
