@charset "UTF-8";
html {
  scroll-behavior: smooth;
}

body {
  font-family: "Syncopate", sans-serif;
  font-family: "Noto Sans JP", sans-serif;
  color: #fff;
  overflow-x: hidden;
}

@media screen and (max-width: 1000px) {
  body {
    font-size: 1.5vw;
  }
}
@media screen and (max-width: 768px) {
  body {
    font-size: 3vw;
  }
}
a {
  display: block;
  transition-duration: 0.3s;
}
a:hover {
  opacity: 0.6;
}

button {
  border: none;
  background-color: transparent;
  cursor: pointer;
  transition-duration: 0.3s;
  padding-block: 0;
  padding-inline: 0;
}

.mv {
  overflow: hidden;
  padding: 150px 0 150px;
  position: relative;
  background:url(../img/mv_bg.png) no-repeat center center / cover;
}
@media screen and (max-width: 768px) {
  .mv {
    padding: 30vw 0 36vw;
    overflow: hidden;
	background:url(../img/mv_bg_sp.png) no-repeat top center / cover;
  }
}
.mv h1 {
  position: absolute;
  top: 33px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  max-width: 335px;
  width: 100%;
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .mv h1 {
    max-width: none;
    width: 36%;
    top: 4vw;
  }
}
.mv_cloud {
  position: absolute;
  z-index: 0;
  top: 68px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  width: 87.5em;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .mv_cloud {
    width: 150%;
    top: 0;
    left: 70%;
  }
}
.mv_left {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0px;
  width:20%;
}
@media screen and (max-width: 768px) {
  .mv_left {
    top: 0%;
    left: 0%;
    width: 34%;
  }
}
.mv_right {
  position: absolute;
  z-index: 2;
  top: 0%;
  right: 0;
  width:25%;
}
@media screen and (max-width: 768px) {
  .mv_right {
    top: 0%;
    width: 30%;
  }
}
.mv_title {
  position: relative;
  z-index: 2;
  max-width: 552px;
  width: 100%;
  margin: 0 auto;
  top: 1.125em;
}
@media screen and (max-width: 768px) {
  .mv_title {
    top: 7vw;
    width: 83%;
  }
}
.mv_title h2 {
  position: relative;
  z-index: 4;
}
.mv_title .circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.mv_title .circle.circle01 {
  width: 76.6%;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle01 {
    width: 56%;
  }
}
.mv_title .circle.circle01.active {
  top: 23.5%;
  left: -14%;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle01.active {
    top: -14%;
    left: 21%;
  }
}
.mv_title .circle.circle02 {
  width: 41%;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle02 {
    width: 35.5%;
  }
}
.mv_title .circle.circle02.active {
  top: 19.4%;
  left: 106.5%;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle02.active {
    top: -19%;
    left: 74%;
  }
}
.mv_title .circle.circle03 {
  width: 62%;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle03 {
    width: 55.5%;
  }
}
.mv_title .circle.circle03.active {
  top: 70%;
  left: 118%;
}
@media screen and (max-width: 768px) {
  .mv_title .circle.circle03.active {
    top: 107%;
    left: 77%;
  }
}
.mv_title .icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.mv_title .icon.icon01 {
  width: 21.7%;
  z-index: 5;
  top: 10%;
  left: 89.5%;
}
@media screen and (max-width: 768px) {
  .mv_title .icon.icon01 {
    top: 9%;
    left: 91%;
  }
}
.mv_title .icon.icon02 {
  width:18%;
  z-index: 5;
  top: 88%;
  left: 84%;
}
@media screen and (max-width: 768px) {
  .mv_title .icon.icon02 {
	top: 46%;
	left: 98%;
	width: 16%;
  }
}
.mv_title .icon.icon03 {
  width:18%;
  z-index: 5;
  top: 95%;
  left:45%;
}
@media screen and (max-width: 768px) {
  .mv_title .icon.icon03 {
    top: 95%;
    left: 76%;
  }
}
.mv_title .icon.icon04 {
  left: 5%;
  top: 95%;
  width: 25%;
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .mv_title .icon.icon04 {
    left:7%;
    top: 100%;
    width:26%;
  }
}
.mv .bg {
  width: 100%;
  position: absolute;
  z-index: 1;
  top:0%;
  left: 0;
}
@media screen and (max-width: 768px) {
  .mv .bg {
    width: 100%;
  }
}
.mv #fall01 {
  position: absolute;
  left: -68%;
  top: -60%;
  width: 130%;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .mv #fall01 {
    left: 0%;
    top: -74%;
    width: 137%;
    z-index: 3;
  }
}
.mv #fall02 {
  position: absolute;
  right: -68%;
  top: -40%;
  width: 120%;
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .mv #fall02 {
    right: -49%;
    top: -46%;
    width: 130%;
    z-index: 3;
  }
}
.mv_under_text_box {
  position: relative;
  margin-top: 2.5em;
  margin-bottom: 3.9375em;
  width: fit-content;
  margin-inline: auto;
}
.mv_under_left {
  position: absolute;
  top: 0;
  left: -11.875em;
  width: 7.5em;
  height: 5em;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .mv_under_left {
    left: -17.0666vw;
    width: 13.333334vw;
    height: auto;
    aspect-ratio: 7.5/5;
  }
}
.mv_under_right {
  position: absolute;
  top: 0;
  right: -8.75em;
  width: 7.0625em;
  height: 5em;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .mv_under_right {
    right: -14.39999vw;
    width: 13.333334vw;
    height: auto;
    aspect-ratio: 7.0625/5;
    top: inherit;
    bottom: 0;
  }
}
.mv_under_text {
  font-size: 1.3125em;
  line-height: 1.85714;
  color: #000;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .mv_under_text {
    font-size: 3.5vw;
    text-align: center;
  }
}

.spot {
  padding-top: 0px;
}
@media screen and (max-width: 768px) {
  .spot {
    padding-top: 0vw;
  }
}
.spot .jumpBnr {
  max-width: 980px;
  margin: 0 auto;
  width: 90%;
}
.spot_inner {
  overflow-x: hidden;
  padding-top: 120px;
}
@media screen and (max-width: 768px) {
  .spot_inner {
    padding-top: 10vw;
  }
}
.spot h3 {
  max-width: 446px;
  width: 100%;
  margin: 0 auto 40px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .spot h3 {
    max-width: none;
    width: 80%;
    margin-bottom: 12vw;
    padding-top: 12vw;
  }
}
.spot .fix .parallax {
  width: 100%;
  height:40vw;
  top: 0;
  left: 0;
  z-index: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
@media screen and (max-width: 768px) {
  .spot .fix .parallax {
    height: 50dvh;
  }
}
.spot .fix .parallax_inner {
  max-width: 980px;
  width: 90%;
}
@keyframes curtain {
  0% {
    transform-origin: top left;
    transform: scaleX(0);
  }
  49.999% {
    transform-origin: top left;
    transform: scaleX(1);
  }
  50% {
    transform-origin: bottom right;
    transform: scaleX(1);
  }
  100% {
    transform-origin: bottom right;
    transform: scaleX(0);
  }
}
.spot .fix .parallax > a {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
}
.spot .fix .parallax > a:hover {
  opacity: 1;
}
.spot .fix .parallax::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 12.9375em;
  height: 12.9375em;
  background-image: url(../img/link_bg_bottom.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 0;
}
.spot .fix .parallax01 {
  background-image: url(../img/link_bg_01.jpg);
}
@media screen and (max-width: 1000px) {
  .spot .fix .parallax01 {
    background-position: left 42% center;
  }
}
@media screen and (max-width: 768px) {
  .spot .fix .parallax01 {
    background-position: left 47% center;
  }
}
.spot .fix .parallax02 {
  background-image: url(../img/link_bg_02.jpg);
}
@media screen and (max-width: 1000px) {
  .spot .fix .parallax02 {
    background-position: left 54% center;
  }
}
@media screen and (max-width: 768px) {
  .spot .fix .parallax02 {
    background-image: url(../img/link_bg_02_sp.jpg);
    background-position: left 27% center;
  }
}
.spot .fix .parallax03 {
  background-image: url(../img/link_bg_03.jpg);
  background-position: bottom center;
}
@media screen and (max-width: 1000px) {
  .spot .fix .parallax03 {
    background-position: bottom right;
  }
}
@media screen and (max-width: 768px) {
  .spot .fix .parallax03 {
    background-image: url(../img/link_bg_03_sp.jpg);
    background-position: bottom center;
  }
}

.ban_block .ban_content .txt_box_01 {
  color: #ff738f;
}
.ban_block .ban_content .txt_box_01 .catch {
  position: absolute;
  bottom: 4.375em;
  left: 0;
  max-width: 976px;
  width: 90%;
  z-index: 1;
}
@media screen and (max-width: 1000px) {
  .ban_block .ban_content .txt_box_01 .catch {
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  .ban_block .ban_content .txt_box_01 .catch {
    width: 70%;
  }
}
.ban_block .ban_content .txt_box_01 .catch .ani_txt_02 {
  margin-top: 20px;
}

.spot_viewing {
  padding: 11.0625em 0 4.375em;
  background-color: #FFF7F8;
  position: relative;
}
@media screen and (max-width: 768px) {
  .spot_viewing {
    padding: 15vw 0 15vw;
    overflow-x: hidden;
    max-width: 100%;
  }
}
.spot_viewing_bg_left {
  position: absolute;
  top: 8%;
  left: 2.825%;
  width: 10.75em;
  height: 29.5em;
}
@media screen and (max-width: 1200px) {
  .spot_viewing_bg_left {
    top: 12%;
    width: 5.75em;
    height: 16.5em;
    overflow: hidden;
  }
}
@media screen and (max-width: 1000px) {
  .spot_viewing_bg_left {
    top: 9%;
  }
}
.spot_viewing_bg_right {
  position: absolute;
  top: 9.5%;
  right: 0;
  width: 17.75em;
  height: 40.4375em;
}
@media screen and (max-width: 1200px) {
  .spot_viewing_bg_right {
    top: 14.5%;
    width: 9.75em;
    height: 21.4375em;
    overflow: hidden;
  }
}
.spot_viewing_bg_bottom_left {
  position: absolute;
  top: 20.5%;
  left: 0;
  width: 17.75em;
  height: 55em;
}
@media screen and (max-width: 1200px) {
  .spot_viewing_bg_bottom_left {
    top: 30.5%;
    width: 8.75em;
    height: 28em;
    overflow: hidden;
  }
}
@media screen and (max-width: 1000px) {
  .spot_viewing_bg_bottom_left {
    top: 26.5%;
  }
}
.spot_viewing_bg_bottom_right {
  position: absolute;
  top: 24%;
  right: 2.825%;
  width: 10.75em;
  height: 29.5em;
}
@media screen and (max-width: 1200px) {
  .spot_viewing_bg_bottom_right {
    top: 32%;
    width: 4.75em;
    height: 14.5em;
    overflow: hidden;
  }
}
.spot_viewing_bg_left_sp {
  content: "";
  position: absolute;
  background-image: url(../img/spot_bg_left_sp.png);
  top: 4%;
  left: 0%;
  width: 7.8205vw;
  height: 25.8%;
  background-size: contain;
  overflow: hidden;
}
.spot_viewing_bg_right_sp {
  content: "";
  position: absolute;
  background-image: url(../img/spot_bg_right_sp.png);
  top: 6%;
  right: 0;
  width: 6.307vw;
  height: 24.7%;
  background-size: contain;
  overflow: hidden;
}
.spot_viewing_inner {
  max-width: 51.25em;
  width: 90%;
  margin-top: 9.125em;
  margin-bottom: 10.6875em;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .spot_viewing_inner {
    width: 92%;
    margin-top: 10.6667vw;
    margin-bottom: 12.8205vw;
  }
}
.spot_viewing_list {
  padding-inline-start: 0;
  margin-block-start: 0;
  margin-block-end: 0;
  display: flex;
  flex-direction: column;
  gap: 7.5em;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .spot_viewing_list {
    gap: 20vw;
  }
}
.spot_viewing .spot_heading {
  max-width: 35em;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .spot_viewing .spot_heading {
    width: 80%;
  }
}
.spot_viewing .spot_heading_left {
  position: absolute;
  top: 0;
  left: -10.9375em;
  width: 9.5em;
  height: 8.625em;
}
@media screen and (max-width: 768px) {
  .spot_viewing .spot_heading_left {
    left: -15.2vw;
    width: 16.466667vw;
    height: 13.673685vw;
  }
}
.spot_viewing .spot_heading_right {
  position: absolute;
  top: 0;
  right: -13.125em;
  width: 12.4375em;
  height: 7.875em;
}
@media screen and (max-width: 768px) {
  .spot_viewing .spot_heading_right {
    top: inherit;
    bottom: 0;
    right: -5.125em;
    width: 13.0666vw;
    height: 8.27332vw;
  }
}
.spot_viewing_item {
  display: flex;
  align-items: center;
  gap: 3em;
}
@media screen and (max-width: 768px) {
  .spot_viewing_item {
    flex-direction: column;
  }
}
.spot_viewing_item_reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .spot_viewing_item_reverse {
    flex-direction: column;
  }
}
.spot_viewing_item_img {
  width: 21.25em;
  height: 21.25em;
}
.spot_viewing_item_txt {
  width: 26.875em;
  text-align: justify;
  letter-spacing: -0.01em;
}
.spot_viewing_item_title {
  margin-bottom: 1.25em;
}
.spot_viewing_item_title_primary {
  width: 15.375em;
}
.spot_viewing_item_title_secondary {
  width: 13.1875em;
}
.spot_viewing_item_title_tertiary {
  width: 26.375em;
}
.spot_viewing_item_title_04 {
  width: 12em;
}
.spot_viewing_item_title_05 {
  width: 12em;
}
.spot_viewing_item_title_06 {
  width: 12em;
}



.spot_viewing_item_content {
  margin-top: 1.25em;
}
.spot_viewing_item_content p {
  font-size: 1.125em;
  line-height: 1.666667;
  color: #000;
}
.spot_viewing_item_info {
  margin-top: 1.75em;
  position: relative;
  padding-top: 1.1875em;
  padding-bottom: 1.3125em;
}
.spot_viewing_item_info::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 26.875em;
  height: 0.375em;
  background-image: url(../img/pink_line.svg);
  background-size: contain;
  background-repeat: repeat-x;
  background-position: center;
}
@media screen and (max-width: 1000px) {
  .spot_viewing_item_info::before {
    width: 25.875em;
    height: 0.35em;
    background-position: left;
    background-repeat: no-repeat;
  }
}
@media screen and (max-width: 768px) {
  .spot_viewing_item_info::before {
    max-width: 85.624vw;
    width: 100%;
    height: 1.2vw;
    background-size: cover;
    background-position: left;
  }
}
.spot_viewing_item_info::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 26.875em;
  height: 0.375em;
  background-image: url(../img/pink_line.svg);
  background-size: contain;
  background-repeat: repeat-x;
  background-position: center;
}
@media screen and (max-width: 1000px) {
  .spot_viewing_item_info::after {
    width: 25.875em;
    height: 0.35em;
    background-position: left;
    background-repeat: no-repeat;
  }
}
@media screen and (max-width: 768px) {
  .spot_viewing_item_info::after {
    max-width: 85.624vw;
    width: 100%;
    height: 1.2vw;
    background-size: cover;
    background-position: left;
  }
}
.spot_viewing_item_info p {
  font-size: 0.875em;
  line-height: 1.666667;
  margin-left: 0.1875em;
  display: flex;
  align-items: center;
  gap: 0.714286em;
  color: #000;
}
@media screen and (max-width: 768px) {
  .spot_viewing_item_info p {
    font-size: 2.666667vw;
  }
}
.spot_viewing_item_info p:not(:first-child) {
  margin-top: 0.5em;
}
.spot_viewing_item_info p.note {
  font-size: 0.625em;
  letter-spacing: -0.02em;
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .spot_viewing_item_info p.note {
    font-size: 0.72em;
    letter-spacing: -0.04em;
  }
}
.spot_viewing_item_info p img {
  width: 1.625em;
  height: 1.625em;
}
.spot_viewing_item_info p a {
  font-weight: bold;
  text-decoration: underline;
  color: #000;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;

}
.spot_viewing_item_category {
  display: flex;
  align-items: center;
  gap: 0.25em;
  margin-bottom: 0.5em;
}
.spot_viewing_bg {
  position: relative;
  z-index: 1;
}

.tableBlock {
  padding: 8.625em 0 1.375em;
  max-width: 78.875em;
  width: 92%;
  margin: 0 auto;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .tableBlock {
    padding: 18vw 0;
  }
}
.tableBlock h3 {
  max-width: 510px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .tableBlock h3 {
    max-width: none;
    width: 68%;
  }
}
.tableBlock .snoway {
  text-align: center;
  color: #ff738f;
  font-weight: bold;
  margin-top: 1.66667em;
  margin-bottom: 2.5em;
  font-size: 1.125em;
  line-height: 1.8;
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .tableBlock .snoway {
    font-size: 3.5vw;
    margin-top: 5vw;
    margin-bottom: 5vw;
  }
}
.tableBlock_inner {
  max-width: 61.25em;
  width: 90%;
  margin: 2.5em auto 0;
  padding: 3.125em 0 3.4375em;
  border-radius: 1.875em;
  background-color: #e0f1ff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .tableBlock_inner {
    margin-top: 14vw;
    padding: 5vw 0 8vw;
    border-radius: 15px;
    width: 92%;
    background-color: transparent;
    padding: 0;
  }
}
.tableBlock_inner .tree01 {
  position: absolute;
  z-index: -1;
  width: 14%;
  left: 3%;
  top: -4.75em;
}
@media screen and (max-width: 768px) {
  .tableBlock_inner .tree01 {
    left: 5vw;
    top: -9.5vw;
    width: 17vw;
  }
}
.tableBlock_inner .tree02 {
  position: absolute;
  z-index: -1;
  width: 11.8%;
  right: 3%;
  top: -3.625em;
}
@media screen and (max-width: 768px) {
  .tableBlock_inner .tree02 {
    top: -6.5vw;
    width: 13vw;
    right: 5vw;
  }
}
.tableBlock_inner .redLeaf {
  position: absolute;
  z-index: -1;
}
.tableBlock_inner .redLeaf.red01 {
  width: 12.5%;
  top: 8%;
  left: -20%;
}
@media screen and (max-width: 768px) {
  .tableBlock_inner .redLeaf.red01 {
    width: 21.5%;
    top: -3%;
    left: -8%;
  }
}
.tableBlock_inner .redLeaf.red02 {
  width: 18.36%;
  top: 47%;
  left: -24%;
}
.tableBlock_inner .redLeaf.red03 {
  width: 11%;
  top: -10%;
  right: -20%;
}
@media screen and (max-width: 768px) {
  .tableBlock_inner .redLeaf.red03 {
    width: 17%;
    top: -3%;
    right: -5%;
  }
}
.tableBlock_inner .redLeaf.red04 {
  width: 17%;
  top: 60%;
  right: -20%;
}
.tableBlock_pre:nth-of-type(n + 2) {
  margin-top: 4.375em;
}
@media screen and (max-width: 768px) {
  .tableBlock_pre:nth-of-type(n + 2) {
    margin-top: 8vw;
  }
}
@media screen and (max-width: 768px) {
  .tableBlock_pre {
    background-color: #dff2fc;
    border-radius: 15px;
    padding: 5vw 0 8vw;
  }
}
.tableBlock_pre h4 {
  text-align: center;
  color: #ff738f;
  font-size: 1.5em;
  font-weight: 900;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
  .tableBlock_pre h4 {
    font-size: 6vw;
  }
}
.tableBlock_pre .pre {
  width: 87.5%;
  margin: 0.9375em auto 0;
  text-align: center;
  color: #000;
  font-weight: 500;
  font-size: 0.9375em;
  letter-spacing: 0em;
}
.tableBlock_pre .pre td,
.tableBlock_pre .pre th {
  border-collapse: collapse;
  background-color: #fff0de;
}
.tableBlock_pre .pre td {
  padding: 1em 0;
  background-image: linear-gradient(to bottom, #ff738f 3px, transparent 3px);
  background-size: 3px 8px;
  background-repeat: repeat-y;
  background-position: top right;
  font-size: 0.875em;
}
.tableBlock_pre .pre td:first-child {
  letter-spacing: 0.05em;
}
.tableBlock_pre .pre td:last-child {
  background-image: none;
}
.tableBlock_pre .pre td a {
  color: #000;
}
.tableBlock_pre .pre td a:hover {
  text-decoration: underline;
}
.tableBlock_pre .pre table {
  border: #ff738f 4px solid;
  border-radius: 1.875em;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}
.tableBlock_pre .pre table tr {
  margin-top: -2px;
}
.tableBlock_pre .pre table tr:first-child td:first-child {
  border-radius: 1.4375em 0 0 0;
}
@media screen and (max-width: 1000px) {
  .tableBlock_pre .pre table tr:first-child td:first-child {
    border-radius: 1em 0 0 0;
  }
}
.tableBlock_pre .pre table tr:first-child td:last-child {
  border-radius: 0 1.4375em 0 0;
}
@media screen and (max-width: 1000px) {
  .tableBlock_pre .pre table tr:first-child td:last-child {
    border-radius: 0 1em 0 0;
  }
}
.tableBlock_pre .pre table tr:last-child td:first-child {
  border-radius: 0 0 0 1.6875em;
}
.tableBlock_pre .pre table tr:last-child td:last-child {
  border-radius: 0 0 1.6875em 0;
}
.tableBlock_pre .pre table tr:nth-child(2n) td {
  background-color: #fff;
}
.tableBlock_pre .pre .topBar {
  color: #fff;
  font-weight: bold;
}
.tableBlock_pre .pre .topBar td {
  padding: 10px 0;
  background-color: #ff738f;
  background-image: linear-gradient(to bottom, #fff 3px, transparent 3px);
  background-size: 3px 8px;
  font-size: 16px;
}
@media screen and (max-width: 1000px) {
  .tableBlock_pre .pre .topBar td {
    line-height: 1.2;
  }
}
.tableBlock_pre .pre .topBar td:first-child {
  width: 25%;
}
.tableBlock_pre .pre .topBar td:nth-child(n+2) {
  width: 17.5%;
}
.tableBlock_pre .pre .topBar td:last-child {
  background-image: none;
  width: 40%;
}
.tableBlock_pre .pre .topBar td span {
  font-size: 14px;
}
.tableBlock_pre .pre_sp {
  width: 92%;
  margin: 6vw auto 0;
}
.tableBlock_pre .pre_sp_box:nth-of-type(n + 2) {
  margin-top: 7vw;
}
.tableBlock_pre .pre_sp_box a {
  display: block;
}
.tableBlock_pre .pre_sp_box a .name {
  padding: 0.5vw 0 0.5vw 2vw;
  background: linear-gradient(90deg, rgb(255, 115, 143) 0%, rgb(255, 115, 143) 75%, rgba(255, 115, 143, 0) 100%);
}
.tableBlock_pre .pre_sp_box a .name p {
  font-size: 4.5vw;
  font-weight: bold;
  color: #fff;
  margin-top: 0;
}
.tableBlock_pre .pre_sp_box a p {
  font-size: 3.8vw;
  letter-spacing: 0.05em;
  color: #000;
  margin-top: 1vw;
  font-weight: 500;
  padding-left: 0.5vw;
}
.tableBlock_pre .pre_sp_box a p span {
  color: #ff738f;
}
.tableBlock_note {
  text-align: center;
  font-size: 12px;
  margin-top: 15px;
  color: #000;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .tableBlock_note {
    font-size: 10px;
    margin-top: 3vw;
  }
}
.tableBlock .eventInfo {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .tableBlock .eventInfo {
    margin-top: 18vw;
  }
}
.tableBlock .eventInfo h4 {
  max-width: 712px;
  width: 90%;
  margin: 0 auto;
}
.tableBlock .eventInfo_btn {
  max-width: 400px;
  width: 100%;
  margin: 25px auto 0;
}
@media screen and (max-width: 768px) {
  .tableBlock .eventInfo_btn {
    max-width: none;
    width: 80%;
    margin-top: 5vw;
  }
}
.tableBlock .eventInfo_btn a {
  display: inline-block;
}

.goingOutSpot {
  position: relative;
  padding-top: 10em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot {
    padding-top: 15vw;
  }
}
.goingOutSpot_side_left {
  position: absolute;
  top: -6px;
  top: 0;
  left: 0;
  width: 7.5625em;
  height: 100%;
  background-image: url(../img/spot_10_side_bg.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
  background-position: center;
  z-index: 0;
}
@media screen and (max-width: 1280px) {
  .goingOutSpot_side_left {
    width: 3vw;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_side_left {
    width: 3.6vw;
  }
}
.goingOutSpot_side_right {
  position: absolute;
  top: -36px;
  top: 0;
  right: 0;
  width: 7.5625em;
  height: 100%;
  background-image: url(../img/spot_10_side_bg.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
  background-position: center;
  z-index: 0;
}
@media screen and (max-width: 1280px) {
  .goingOutSpot_side_right {
    width: 3vw;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_side_right {
    width: 3.6vw;
    height: 100%;
    top: -3.2vw;
  }
}
.goingOutSpot_note {
  font-size: 1.25em;
  color: #000;
  text-align: center;
  margin-top: 1.5em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_note {
    letter-spacing: 0;
  }
}
.goingOutSpot_inner {
  max-width: 60em;
  width: 90%;
  margin-inline: auto;
  padding-bottom: 7.5em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_inner {
    width: 92%;
  }
}
.goingOutSpot_heading {
  position: relative;
  max-width: 36.5625em;
  width: 90%;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_heading {
    width: 80%;
  }
}
.goingOutSpot_heading_left {
  position: absolute;
  bottom: 0;
  left: -10.5em;
  width: 9.875em;
  height: 9em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_heading_left {
    left: -13.33334vw;
    width: 13.33334vw;
    height: auto;
  }
}
.goingOutSpot_heading_right {
  position: absolute;
  bottom: 0;
  right: -10.9375em;
  width: 8.4375em;
  height: 10.1875em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_heading_right {
    right: -13.3334vw;
    width: 12vw;
    height: auto;
  }
}
.goingOutSpot_list {
  padding-inline-start: 0;
  margin-block-start: 0;
  margin-block-end: 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  row-gap: 9.75em;
  margin-top: 6.125em;
  position: relative;
  z-index: 1;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1000px) {
  .goingOutSpot_list {
    justify-content: center;
    column-gap: 3vw;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_list {
    row-gap: 10vw;
    margin-top: 8vw;
  }
}
.goingOutSpot_item {
  width: 26.875em;
}
.goingOutSpot_item_location {
  font-size: 1.125em;
  letter-spacing: 0.05em;
  text-align: center;
  color: #fff;
  padding-block: 0.2778em;
  width: 17.6875em;
  min-height: 1.8333em;
  border-radius: 1.66667em;
  background: #ff639c;
  margin-inline: auto;
  margin-top: 1.5556em;
}
.goingOutSpot_item_img {
  width: 21.25em;
  height: 21.25em;
  margin-inline: auto;
  display: block;
  overflow: hidden;
  border-radius: 9999px;
}
.goingOutSpot_item_img_area {
  position: relative;
  width: 21.25em;
  height: 21.25em;
  margin-inline: auto;
}
.goingOutSpot_item_img_area_category {
  position: absolute;
  bottom: 0;
  right: 0;
  margin-bottom: 0;
}
.goingOutSpot_item_img img {
  transition: transform 0.3s ease;
}
@media (min-width: 769px) {
  .goingOutSpot_item_img:hover img {
    transform: scale(1.1);
  }
}
.goingOutSpot_item_txt {
  width: 26.875em;
  text-align: justify;
  letter-spacing: -0.01em;
}
.goingOutSpot_item_title {
  margin-top: 1.75em;
  margin-bottom: 1.25em;
  margin-inline: auto;
}
.goingOutSpot_item_title_primary {
  width: 15.375em;
}
.goingOutSpot_item_title_secondary {
  width: 9.6875em;
}
.goingOutSpot_item_title_tertiary {
  width: 21.5625em;
}
.goingOutSpot_item_title_quaternary {
  width: 17.5em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_title_quaternary {
    margin-top: 1.75em;
    width: 20.5em;
  }
}
.goingOutSpot_item_title_quinary {
  width: 22.4375em;
}
.goingOutSpot_item_title_senary {
  width: 17.5em;
}
.goingOutSpot_item_title_septenary {
  width: 17.3125em;
}
.goingOutSpot_item_title_octonary {
  width: 21.75em;
}
.goingOutSpot_item_title_nonary {
  width: 21.6875em;
}
.goingOutSpot_item_title_decenary {
  width: 10.6875em;
}
.goingOutSpot_item_title_11{
  width: 20em;
}
.goingOutSpot_item_title_12{
  width: 17em;
}
.goingOutSpot_item_title_13{
  width: 22em;
}


.goingOutSpot_item_content {
  margin-top: 1.25em;
}
.goingOutSpot_item_content p {
  font-size: 1.125em;
  line-height: 1.666667;
  color: #000;
  letter-spacing: -0.042em;
}
.goingOutSpot_item_content .ls8 {
  letter-spacing: -0.08em;
}
.goingOutSpot_item_content_mg {
  margin-top: 2em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_content_mg {
    margin-top: 1.75em;
  }
}
.goingOutSpot_item_info {
  margin-top: 1.75em;
  position: relative;
  min-height: 11em;
  padding: 1em 0;
  display: flex;
  justify-content: center;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info_sp_height {
    height: 13em;
  }
}
.goingOutSpot_item_info_mg {
  margin-top: 3.5em;
}
@media screen and (max-width: 1000px) {
  .goingOutSpot_item_info_mg {
    margin-top: 3.65em;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info_mg {
    margin-top: 1.75em;
  }
}
.goingOutSpot_item_info_mg_secodary {
  margin-top: 3.5em;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info_mg_secodary {
    margin-top: 1.75em;
  }
}
.goingOutSpot_item_info::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 26.875em;
  height: 0.375em;
  background-image: url(../img/pink_line.svg);
  background-size: contain;
  background-repeat: repeat-x;
  background-position: center;
}
@media screen and (max-width: 1000px) {
  .goingOutSpot_item_info::before {
    width: 27em;
    height: 0.4em;
    background-size: cover;
    background-position: left;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info::before {
    max-width: 85.624vw;
    width: 100%;
    height: 1.2vw;
    background-size: cover;
    background-position: left;
  }
}
.goingOutSpot_item_info::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 26.875em;
  height: 0.375em;
  background-image: url(../img/pink_line.svg);
  background-size: contain;
  background-repeat: repeat-x;
  background-position: center;
}
@media screen and (max-width: 1000px) {
  .goingOutSpot_item_info::after {
    width: 27em;
    height: 0.4em;
    background-size: cover;
    background-position: left;
  }
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info::after {
    max-width: 85.624vw;
    width: 100%;
    height: 1.2vw;
    background-size: cover;
    background-position: left;
  }
}
.goingOutSpot_item_info .note {
  font-size: 0.625em;
  letter-spacing: -0.02em;
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info .note {
    font-size: 0.72em;
    letter-spacing: -0.04em;
  }
}
.goingOutSpot_item_info p {
  font-size: 0.875em;
  line-height: 1.666667;
  margin-left: 0.1875em;
  display: flex;
  align-items: center;
  gap: 0.714286em;
  color: #000;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info p {
    font-size: 2.666667vw;
  }
}
.goingOutSpot_item_info p:not(:first-child) {
  margin-top: 0.5em;
}
.goingOutSpot_item_info p.mg_0 {
  margin-top: 0;
}
.goingOutSpot_item_info p.baseline {
  align-items: baseline;
}
.goingOutSpot_item_info p.block {
  display: block;
}
.goingOutSpot_item_info p.note {
  font-size: 0.625em;
  letter-spacing: -0.02em;
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .goingOutSpot_item_info p.note {
    font-size: 0.72em;
    letter-spacing: -0.04em;
  }
}
.goingOutSpot_item_info p .lh_140 {
  line-height: 1.4;
}
.goingOutSpot_item_info p img {
  width: 1.625em;
  height: 1.625em;
}
.goingOutSpot_item_info p a {
  font-weight: bold;
  text-decoration: underline;
  line-height: 1.3;
  color: #000;
  word-break: break-all;
}
.goingOutSpot_bg {
  position: relative;
  z-index: 1;
}

.foodSpot {
  background: rgba(255, 252, 161, 0.25);
  padding-top: 10em;
  position: relative;
}
@media screen and (max-width: 1000px) {
  .foodSpot {
    overflow: hidden;
  }
}
@media screen and (max-width: 768px) {
  .foodSpot {
    padding-top: 10vw;
    overflow-x: hidden;
  }
}

/*
.foodSpot_side_left {
  position: absolute;
  top: 16.9875em;
  top: 10%;
  left: -2.25em;
  width: 8.8125em;
  height: calc(100% - 62.1875em);
  background-image: url(../img/spot_9_side_bg_left.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
  background-position: top;
}
@media screen and (max-width: 1200px) {
  .foodSpot_side_left {
    width: 6vw;
    left: 0;
  }
}
@media screen and (max-width: 1000px) {
  .foodSpot_side_left {
    width: 5vw;
  }
}
@media screen and (max-width: 768px) {
  .foodSpot_side_left {
    width: 10vw;
    top: 4%;
    left: -4vw;
    height: 92.5%;
  }
}
.foodSpot_side_right {
  position: absolute;
  top: 29.375em;
  top: 10.5%;
  right: -2.1875em;
  width: 8.8125em;
  height: calc(100% - 49.375em);
  background-image: url(../img/spot_9_side_bg_right.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
  background-position: top;
}
@media screen and (max-width: 1200px) {
  .foodSpot_side_right {
    width: 6vw;
    right: 0;
  }
}
@media screen and (max-width: 1000px) {
  .foodSpot_side_right {
    width: 5vw;
    height: calc(100% - 51.375em);
  }
}
@media screen and (max-width: 768px) {
  .foodSpot_side_right {
    width: 10vw;
    top: 5.5%;
    right: -4vw;
    height: 90.7%;
  }
}
*/
.foodSpot_inner {
  max-width: 60em;
  width: 90%;
  margin-inline: auto;
  padding-bottom: 11.625em;
}
@media screen and (max-width: 768px) {
  .foodSpot_inner {
    width: 92%;
  }
}
.foodSpot_heading {
  position: relative;
  max-width: 41.75em;
  width: 90%;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .foodSpot_heading {
    width: 90%;
  }
}
.foodSpot_heading_left {
  position: absolute;
  bottom: 0;
  left: -12.1875em;
  width: 13.375em;
  height: 10.8125em;
}
@media screen and (max-width: 768px) {
  .foodSpot_heading_left {
    left: -15.06666vw;
    width: 18.666667vw;
    height: auto;
  }
}
.foodSpot_heading_right {
  position: absolute;
  bottom: 0;
  right: -10.3125em;
  width: 8.125em;
  height: 5em;
}
@media screen and (max-width: 768px) {
  .foodSpot_heading_right {
    right: -13.399vw;
    width: 12.8vw;
    height: auto;
  }
}
.foodSpot_item.last {
  margin-inline: auto;
}
.foodSpot_item_location {
  background-color: #e8a023;
}
.foodSpot_item_title_primary {
  width: 12.75em;
}
.foodSpot_item_title_secondary {
  width: 15.25em;
}
.foodSpot_item_title_tertiary {
  width: 6.5em;
}
.foodSpot_item_title_quaternary {
  width: 21.75em;
}
.foodSpot_item_title_quinary {
  width: 15.125em;
  margin-top: 2.8125em;
}
.foodSpot_item_title_10 {
  width: 12em;
}
.foodSpot_item_title_11 {
  width: 17em;
}
.foodSpot_item_title_12 {
  width: 18em;
}




@media screen and (max-width: 768px) {
  .foodSpot_item_title_quinary {
    margin-top: 1.6em;
  }
}
.foodSpot_item_title_senary {
  width: 22.9375em;
}
.foodSpot_item_title_septenary {
  width: 13.5625em;
}
.foodSpot_item_title_octonary {
  width: 12.75em;
}
.foodSpot_item_title_nonary {
  width: 8.625em;
}
.foodSpot_item_content p {
  letter-spacing: -0.04em;
}
.foodSpot_item_content p.ls_112 {
  letter-spacing: -0.112em;
}
.foodSpot_item_info::before, .foodSpot_item_info::after {
  background-image: url(../img/orange_line.svg);
}
.foodSpot_item_info_mg {
  margin-top: 3.5em;
}
.foodSpot_item_info p em {
  font-style: normal;
  color: #fc0b0b;
}
.foodSpot_bg {
  margin-bottom: -1px;
}
@media screen and (max-width: 768px) {
  .foodSpot_bg {
    margin-bottom: 0;
  }
}

.lineCont {
  padding: 75px 0 120px;
  background-color: #ffffc5;
}
@media screen and (max-width: 768px) {
  .lineCont {
    padding: 6vw 0 18vw;
  }
}
.lineCont .addfriend h3 {
  max-width: 846px;
  width: 90%;
  margin: 0 auto;
}
.lineCont .addfriend_inner {
  max-width: 980px;
  width: 90%;
  margin: 40px auto 0;
  position: relative;
  background-color: #fff;
  padding: 50px 35px 35px 25px;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner {
    margin-top: 6vw;
    padding: 10vw 5vw 9vw 3vw;
  }
}
.lineCont .addfriend_inner .special_ab {
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  max-width: 424px;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .special_ab {
    max-width: none;
    width: 80%;
    top: -3vw;
  }
}
.lineCont .addfriend_inner .special {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .special {
    flex-direction: column;
  }
}
.lineCont .addfriend_inner .special_box {
  width: 32%;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .special_box {
    width: 100%;
    margin-top: 4vw;
  }
  .lineCont .addfriend_inner .special_box:first-of-type {
    margin-top: 0;
  }
}
.lineCont .addfriend_inner .special_box04 {
  width: 104%;
  margin-left: -4%;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .special_box04 {
    width: 108%;
    margin-left: -8%;
    margin-top: 7vw;
  }
}
.lineCont .addfriend_inner .pointBlock {
  max-width: 600px;
  width: 90%;
  margin: 10px auto 0;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock {
    max-width: none;
    width: 96%;
    margin-top: 4vw;
  }
}
.lineCont .addfriend_inner .pointBlock_box {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.lineCont .addfriend_inner .pointBlock_box:nth-of-type(n + 2) {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box:nth-of-type(n + 2) {
    margin-top: 4vw;
  }
}
.lineCont .addfriend_inner .pointBlock_box .pointNum {
  width: 69px;
  margin-right: 10px;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box .pointNum {
    width: 14vw;
    margin-right: 2vw;
  }
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box .pointTxt {
    width: 84%;
  }
}
.lineCont .addfriend_inner .pointBlock_box .pointTxt p {
  font-size: 1.5em;
  font-weight: bold;
  color: #4e2f2f;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box .pointTxt p {
    font-size: 3.5vw;
  }
}
.lineCont .addfriend_inner .pointBlock_box .pointTxt p span {
  font-size: 1.2em;
  color: #ff7f00;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box .pointTxt p span {
    font-size: 5vw;
  }
}
.lineCont .addfriend_inner .pointBlock_box .pointTxt p.note {
  font-size: 0.85em;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_inner .pointBlock_box .pointTxt p.note {
    font-size: 2.5vw;
  }
}
.lineCont .addfriend_btnArea {
  max-width: 930px;
  width: 90%;
  margin: 50px auto 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_btnArea {
    flex-direction: column;
    margin-top: 12vw;
  }
}
.lineCont .addfriend_btnArea_btn {
  width: 62.04%;
  margin: 0 auto;
  box-shadow: 8px 10px 0px -2px rgba(0, 0, 0, 0.15);
  border-radius: 70px;
  transition-duration: 0.3s;
}
.lineCont .addfriend_btnArea_btn:hover {
  transform: translate(8px, 10px);
  box-shadow: none;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_btnArea_btn {
    width: 100%;
  }
}
.lineCont .addfriend_btnArea .qr {
  width: 34.94%;
}
@media screen and (max-width: 768px) {
  .lineCont .addfriend_btnArea .qr {
    width: 80%;
    margin-top: 8vw;
  }
}
.lineCont .rakuregi {
  margin-top: 50px;
  padding-top: 50px;
  background-image: linear-gradient(to right, #7d7d7d 3px, transparent 3px);
  background-size: 8px 3px;
  background-repeat: repeat-x;
  background-position: top left;
  position: relative;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi {
    margin-top: 12vw;
    padding-top: 12vw;
  }
}
.lineCont .rakuregi h4 {
  max-width: 384px;
  width: 90%;
  margin: 0 auto;
}
.lineCont .rakuregi_icon {
  position: absolute;
  width: 21.36%;
  top: 60px;
  right: 5%;
}
@media screen and (max-width: 1000px) {
  .lineCont .rakuregi_icon {
    width: 28.36%;
    top: -3vw;
    right: 0vw;
  }
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_icon {
    top: -3vw;
    right: -3vw;
    width: 36vw;
  }
}
.lineCont .rakuregi_step {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_step {
    margin-top: 7vw;
    flex-direction: column;
    align-items: center;
  }
}
.lineCont .rakuregi_stepBox {
  width: 33.33333%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  height: 318px;
  background-image: linear-gradient(to bottom, #7d7d7d 3px, transparent 3px);
  background-size: 3px 8px;
  background-repeat: repeat-y;
  background-position: top right;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox {
    width: 100%;
    height: auto;
    margin-bottom: 12vw;
    padding-bottom: 12vw;
    background-image: linear-gradient(to right, #7d7d7d 3px, transparent 3px);
    background-size: 8px 3px;
    background-repeat: repeat-x;
    background-position: bottom left;
  }
}
.lineCont .rakuregi_stepBox::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -3.5%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 17px 0 17px 22px;
  border-color: transparent transparent transparent #4e2f2f;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox::after {
    position: absolute;
    top: auto;
    bottom: -3vw;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6vw 6vw 0 6vw;
    border-color: #4e2f2f transparent transparent transparent;
  }
}
.lineCont .rakuregi_stepBox:last-of-type {
  background-image: none;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox:last-of-type {
    padding-bottom: 0;
    margin-bottom: 0;
  }
}
.lineCont .rakuregi_stepBox:last-of-type::after {
  display: none;
}
.lineCont .rakuregi_stepBox .boxbb {
  width: 100%;
}
.lineCont .rakuregi_stepBox h5 {
  width: 70%;
  margin: 0 auto;
}
.lineCont .rakuregi_stepBox_p {
  font-size: 14px;
  font-weight: 500;
  color: #4e2f2f;
  text-align: center;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_p {
    font-size: 3.5vw;
    margin-top: 3vw;
  }
}
.lineCont .rakuregi_stepBox_img {
  margin: 0 auto;
}
.lineCont .rakuregi_stepBox_img.img01 {
  width: 41.4%;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_img.img01 {
    width: 53.4%;
    margin-top: 4vw;
  }
}
.lineCont .rakuregi_stepBox_img.img02 {
  width: 86%;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_img.img02 {
    width: 96%;
    margin-top: 4vw;
  }
}
.lineCont .rakuregi_stepBox_img.img03 {
  width: 74%;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_img.img03 {
    width: 100%;
  }
}
.lineCont .rakuregi_stepBox_img.img03 .img {
  width: 60%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_img.img03 .img {
    width: 68%;
    margin-top: 4vw;
  }
}
.lineCont .rakuregi_stepBox_img.img03 .note {
  margin-top: 2px;
  font-size: 10px;
  color: #4e2f2f;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_stepBox_img.img03 .note {
    margin-top: 2vw;
  }
}
.lineCont .rakuregi_stepBox p {
  letter-spacing: 0.05em;
}
.lineCont .rakuregi_note {
  color: #4e2f2f;
  font-size: 12px;
  text-align: center;
  margin-top: 30px;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .lineCont .rakuregi_note {
    font-size: 10px;
    text-align: left;
    margin-top: 12vw;
  }
}

.present {
  background-image: url(../img/cam_bg.png);
  background-size: cover;
  background-position: center top;
  padding-top: 70px;
  padding-bottom: 90px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .present {
    background-image: url(../img/cam_bg_sp.png);
    padding-top: 10vw;
    padding-bottom: 12vw;
  }
}
.present_bg {
  position: absolute;
  z-index: 1;
  width: 100%;
  top: 0;
  left: 0;
}
.present h3 {
  max-width: 940px;
  width: 90%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .present h3 {
    width: 90%;
  }
}
.present_inner {
  max-width: 940px;
  width: 90%;
  margin: 40px auto 0;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .present_inner {
    margin-top: 10vw;
  }
}
.present_quiz {
  position: relative;
}
.present_quiz_txt {
  margin-top: 30px;
  text-align: center;
}
.present_quiz_txt .leadTxt {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .present_quiz_txt .leadTxt {
    font-size: 3.8vw;
  }
}
.present_quiz_txt .noteTxt {
  font-size: 12px;
  letter-spacing: 0.05em;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .present_quiz_txt .noteTxt {
    font-size: 10px;
    margin-top: 3vw;
  }
}
.present_cont {
  margin-top: 70px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .present_cont {
    margin-top: 14vw;
  }
}
.present_cont h4 {
  max-width: 384px;
  width: 90%;
  margin: 0 auto;
}
.present_cont_inner {
  max-width: 830px;
  width: 100%;
  margin: 0 auto;
}
.present_cont_fb {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .present_cont_fb {
    margin-top: 4vw;
    flex-direction: column;
    align-items: center;
  }
}
.present_cont_info {
  width: 43.5%;
}
@media screen and (max-width: 768px) {
  .present_cont_info {
    width: 70%;
  }
}
.present_cont_info_txtArea {
  margin-top: 10px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.01em;
  color: #4e2f2f;
}
@media screen and (max-width: 768px) {
  .present_cont_info_txtArea {
    font-size: 3.5vw;
    text-align: center;
    margin-top: 8vw;
    line-height: 2;
  }
}
.present_cont_info_txtArea a {
  color: #4e2f2f;
  display: inline-block;
  text-decoration: underline;
  margin-top: 5px;
}
@media screen and (max-width: 768px) {
  .present_cont_info_txtArea a {
    margin-top: 2vw;
  }
}
.present_cont_img {
  width: 53.4%;
}
@media screen and (max-width: 768px) {
  .present_cont_img {
    width: 100%;
    margin-top: 5vw;
  }
}
.present_cont_award_headline {
  max-width: 504px;
  width: 100%;
  margin: 40px auto 0;
}
.present_cont_award_cont {
  max-width: 650px;
  width: 100%;
  margin: 0 auto;
  transform: translateX(-27px);
}
@media screen and (max-width: 768px) {
  .present_cont_award_cont {
    transform: translateX(-2vw);
  }
}
.present_btn {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .present_btn {
    margin-top: 10vw;
  }
}
.present_btn a {
  display: block;
  width: 71%;
  margin: 0 auto;
  box-shadow: 8px 10px 0px -2px rgba(0, 0, 0, 0.15);
  border-radius: 70px;
  transition-duration: 0.3s;
}
.present_btn a:hover {
  transform: translate(8px, 10px);
  box-shadow: none;
}
@media screen and (max-width: 768px) {
  .present_btn a {
    width: 94%;
  }
}
.present_btn .txt {
  text-align: center;
  font-size: 16px;
  color: #15073e;
  letter-spacing: 0.05em;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .present_btn .txt {
    font-size: 3vw;
    letter-spacing: 0.05em;
    margin-top: 4vw;
  }
}

.modal {
  font-size: 16px;
  display: none;
}
.modal.is-open {
  display: block;
}
@media screen and (max-width: 768px) {
  .modal {
    font-size: 3.5vw;
  }
}

.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 100;
}

.modal__container {
  background-color: #fff;
  padding: 40px 0 50px;
  width: 90%;
  max-width: 1000px;
  max-height: 100vh;
  border-radius: 4px;
  overflow-y: auto;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .modal__container {
    padding: 8vw 0 12vw;
  }
}

.modal_location {
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .modal_location {
    padding-block: 0.15em;
    width: 13.6875em;
    min-height: 1.4em;
  }
}

.modal__title {
  margin-top: 1.25em;
  scale: 0.8;
}
@media screen and (max-width: 1000px) {
  .modal__title {
    margin-top: 0.5em;
  }
}
@media screen and (max-width: 768px) {
  .modal__title {
    max-width: 80vw;
    scale: 0.6;
    margin-top: 3.2vw;
    margin-top: 1.2vw;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.foodSpot_item_title_primary {
    width: 9.75em;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.foodSpot_item_title_senary {
    scale: 0.8;
    margin-top: 1.6vw;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.foodSpot_item_title_quaternary {
    scale: 0.7;
    margin-top: 1.5vw;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.goingOutSpot_item_title_quinary {
    scale: 0.8;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.goingOutSpot_item_title_octonary {
    scale: 0.8;
    margin-top: 2.2vw;
  }
}
@media screen and (max-width: 768px) {
  .modal__title.goingOutSpot_item_title_nonary {
    scale: 0.8;
  }
}

.modal .splide__arrow {
  background: #ff639c;
}
.modal .splide__arrow svg {
  fill: #fff;
}

.modal .modal__container--food .splide__arrow {
  background: #e8a023;
}

.modal .splide__arrow--next {
  right: -3em;
}
@media screen and (max-width: 768px) {
  .modal .splide__arrow--next {
    right: -7vw;
  }
}

.modal .splide__arrow--prev {
  left: -3em;
}
@media screen and (max-width: 768px) {
  .modal .splide__arrow--prev {
    left: -7vw;
  }
}

.modal .splide__pagination {
  bottom: -1.5em;
  left: 50%;
  transform: translateX(-50%);
  width: fit-content;
}

.modal .splide__pagination__page.is-active {
  background: #868686;
}

.splide:not(.is-overflow) .splide__pagination {
  display: block;
}

.modal .modal__close {
  background: transparent;
  border: 0;
  position: absolute;
  top: 0;
  right: 0;
  padding: 1rem 1.1rem;
  font-size: 2.5rem;
  cursor: pointer;
  background-color: #ff639c;
  line-height: 1;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .modal .modal__close {
    font-size: 1.5em;
  }
}
.modal .modal__close.modal__close--food {
  background-color: #e8a023;
}

.modal__header .modal__close:before {
  content: "✕";
}

.modal__content {
  margin-top: 2rem;
  margin-bottom: 2rem;
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.8);
}

.modal__btn {
  font-size: 0.875rem;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  background-color: #e6e6e6;
  color: rgba(0, 0, 0, 0.8);
  border-radius: 0.25rem;
  border-style: none;
  border-width: 0;
  cursor: pointer;
  -webkit-appearance: button;
  appearance: button;
  text-transform: none;
  overflow: visible;
  line-height: 1.15;
  margin: 0;
  will-change: transform;
  -moz-osx-font-smoothing: grayscale;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  transition: -webkit-transform 0.25s ease-out;
  transition: transform 0.25s ease-out;
  transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out;
}

.modal__btn:focus,
.modal__btn:hover {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.modal__btn-primary {
  background-color: #00449e;
  color: #fff;
}

@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(15%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-10%);
  }
}
.micromodal-slide {
  display: none;
}

.micromodal-slide.is-open {
  display: block;
}

.micromodal-slide[aria-hidden=false] .modal__overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=false] .modal__container {
  animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=true] .modal__overlay {
  animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide[aria-hidden=true] .modal__container {
  animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.micromodal-slide .modal__container,
.micromodal-slide .modal__overlay {
  will-change: transform;
}

.modal .splide {
  width: 80%;
  margin: 1em auto 0;
}
@media screen and (max-width: 768px) {
  .modal .splide {
    margin-top: -4.26777vw;
  }
}
.modal .splide .splide__slide img {
  width: 100%;
}
.modal .splide .splide__slide p {
  margin-top: 1em;
  font-size: 1em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
  color: #481718;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .modal .splide .splide__slide p {
    text-align: left;
  }
}
.modal .splide .splide__list {
  margin-block-start: 0;
  margin-block-end: 0;
}

.category_list {
  display: flex;
  justify-content: center;
  width: fit-content;
  gap: 1.375em;
  margin-inline: auto;
  margin-block-start: 0;
  margin-block-end: 0;
  padding-inline-start: 0;
  margin-top: 2.5em;
}
@media screen and (max-width: 768px) {
  .category_list {
    flex-wrap: wrap;
    gap: 0;
    row-gap: 2.666667vw;
  }
}
.category_item {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
@media screen and (max-width: 768px) {
  .category_item {
    width: 34%;
  }
}
.category_item p {
  font-size: 1.125em;
  letter-spacing: -0.05em;
  line-height: 1.66667;
  color: #000;
}
.category_item figure {
  margin-block-start: 0;
  margin-block-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
}
.category_item img {
  width: 2.25em;
  height: 2.25em;
}

.snsArea {
  color: #000;
}

.floating {
  position: fixed;
  top: 50%;
  right: 0%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  opacity: 0;
  transition-duration: 0.3s;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .floating {
    top: auto;
    bottom: 0;
    transform: none;
    display: flex;
    width: 100%;
  }
}
.floating.is-active {
  opacity: 1;
}
.floating li {
  width: 60px;
  transition-duration: 0.3s;
  list-style: none;
}
@media screen and (max-width: 1000px) {
  .floating li {
    width: 43px;
  }
}
@media screen and (max-width: 768px) {
  .floating li {
    width: auto;
  }
}
.floating li:nth-of-type(n + 2) {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .floating li:nth-of-type(n + 2) {
    margin-top: 0vw;
  }
}
.floating li a {
  display: block;
}
.floating li:hover a {
  opacity: 0.6;
}

.floating2.lineCam {
  position: fixed;
  left: 0;
  top: auto;
  bottom: 40px;
  width: 350px;
  transform: none;
  opacity: 0;
  transition-duration: 0.3s;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .floating2.lineCam {
    bottom: 10vw;
    transform: none;
    width: 54%;
  }
}
.floating2.lineCam.is-active {
  opacity: 1;
}

@media screen and (max-width: 1000px) {
  .tab-none {
    display: none;
  }
}

.tab-block {
  display: none;
}
@media screen and (max-width: 1000px) {
  .tab-block {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .sp-none {
    display: none;
  }
}

.sp-block {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp-block {
    display: block;
  }
}

@keyframes fadeA {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeAndTranslate {
  from {
    opacity: 0;
    transform: translateY(-30%);
  }
  to {
    opacity: 1;
    transform: translateY(-50%);
  }
}
@keyframes lightA {
  0% {
    opacity: 0;
    transform: translateY(-30px) scale(1.4);
  }
  50% {
    opacity: 0.5;
    transform: translateY(-15px) scale(1.2);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes fadeAndTranslate_scale {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  80% {
    opacity: 1;
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fadeAndTranslate_right {
  from {
    opacity: 0;
    transform: translateX(70px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* アニメーションを適用するクラス */
.animate-on-appear {
  animation: fadeAndTranslate 1s ease forwards;
}

.animate-on-appear02 {
  animation: fadeA 1s ease forwards;
}

.animate-on-appear_light {
  animation: lightA 0.5s linear forwards;
}

.animate-on-appear_scale {
  animation: fadeAndTranslate_scale 1s ease-in-out forwards;
}

.animate-on-appear_soon {
  animation: fadeA 0.3s ease forwards;
}

.animate-on-appear_right {
  animation: fadeAndTranslate_right 1s ease forwards;
}





/* LINE友だち登録 */
.line_cam {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  background-color:#41cc33;
}
@media screen and (max-width: 768px) {
  .line_cam {
    flex-direction: column-reverse;
  }
}
.line_cam .left {
  width: 65.3472222vw;
  background-color: #41cc33;
  height: 38.56vw;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1000px) {
  .line_cam .left {
    height: 38.9vw;
  }
}
@media screen and (max-width: 768px) {
  .line_cam .left {
    width: 100%;
    height: auto;
    padding-top: 7.19999vw;
    padding-bottom: 11.466666vw;
    text-align: center;
  }
}
.line_cam .left .line_cam_catch {
  width: 42.375em;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .line_cam .left .line_cam_catch {
    width: 68.667vw;
  }
}
.line_cam .left .line_cam_title {
  font-size: 2.5em;
  line-height: 1.5;
  text-align: center;
  margin-top: 0.9em;
  margin-bottom: 0.6em;
  font-weight: 700;
  color: #fff;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .line_cam .left .line_cam_title {
    font-size: 5.3333334vw;
    margin-top: 5.3333333vw;
    margin-bottom: 3.06666vw;
  }
}
.line_cam .left .line_cam_text {
  display: flex;
  align-items: flex-end;
  column-gap: 1.5em;
  margin-inline: auto;
  width: fit-content;
}
.line_cam .left .line_cam_text .line_cam_text_left {
  width: 9.6875em;
}
@media screen and (max-width: 768px) {
  .line_cam .left .line_cam_text .line_cam_text_left {
    display: none;
  }
}
.line_cam .left .line_cam_text .txt {
  font-size: 0.9375em;
  letter-spacing: -0.07em;
  line-height: 1.6;
  color: #fff;
}
.line_cam .left .line_cam_text .line_btn {
  width: 23.875em;
  margin-top: 1.0625em;
}
@media screen and (max-width: 768px) {
  .line_cam .left .line_cam_text .line_btn {
    width: 77.6vw;
    margin-top: 5.3334vw;
  }
}
.line_cam .right {
  width: 36.5277vw;
}
@media screen and (max-width: 768px) {
  .line_cam .right {
    width: 100%;
    height: 40.8vw;
  }
}












