@charset "UTF-8";
/* ========== ========== ==========
共通部
========== ========== ========== */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 50px;
  font-size: 0.6944444444vw;
}
@media screen and (max-width: 768px) {
  html {
    font-size: 2.3255813953vw;
  }
}

body {
  background-image: url("../img/back.svg");
  background-repeat: repeat-y;
  background-size: 100% auto;
}
body * {
  line-height: 1.8;
  font-family: var(--font-main);
  letter-spacing: 0.06em;
  color: var(--color-text);
}
@media screen and (max-width: 768px) {
  body {
    background-image: url("../img/back-sp.svg");
  }
}

.pageTop {
  padding-top: var(--header-height);
}

#html #body .sp-show,
#html #body .sp-show-flex {
  display: none;
}

@media screen and (max-width: 768px) {
  #html #body .sp-show {
    display: block;
  }
  #html #body .sp-show-flex {
    display: flex;
  }
  #html #body .sp-hide {
    display: none;
  }
}
#html #body .tb-show,
#html #body .tb-show-flex {
  display: none;
}

@media screen and (max-width: 1000px) {
  #html #body .tb-show {
    display: block;
  }
  #html #body .tb-show-flex {
    display: flex;
  }
  #html #body .tb-hide {
    display: none;
  }
}
.inline {
  display: inline;
}

.inline-block {
  display: inline-block;
}

@media screen and (max-width: 768px) {
  .inline-block-sp {
    display: inline-block;
  }
}

span {
  font-weight: inherit;
  color: inherit;
}

.text-center {
  text-align: center;
}

.color-red {
  color: red;
}

.-hidden {
  visibility: hidden;
  pointer-events: none;
}

.sectionWrap {
  width: 100%;
  padding-inline: 16rem;
}
@media screen and (max-width: 768px) {
  .sectionWrap {
    padding-inline: 2.4rem;
  }
}

.sectionWrap-left {
  width: 100%;
  padding-left: var(--section-padding-pc-maxWidth);
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .sectionWrap-left {
    width: 100%;
    padding-left: var(--section-padding-sp);
  }
}

.sectionWrap-right {
  width: 100%;
  padding-right: var(--section-padding-pc-maxWidth);
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .sectionWrap-right {
    width: 100%;
    padding-right: var(--section-padding-sp);
  }
}

.sectionWrap2 {
  width: 100%;
  padding-inline: 16rem;
  padding-inline: var(--section-padding-pc2-maxWidth);
}
@media screen and (max-width: 768px) {
  .sectionWrap2 {
    padding-inline: 2.4rem;
  }
}

.sectionWrap2-left {
  width: 100%;
  padding-left: var(--section-padding-pc-maxWidth);
  margin-left: auto;
  padding-left: var(--section-padding-pc2-maxWidth);
}
@media screen and (max-width: 768px) {
  .sectionWrap2-left {
    width: 100%;
    padding-left: var(--section-padding-sp);
  }
}

.sectionWrap2-right {
  width: 100%;
  padding-right: var(--section-padding-pc-maxWidth);
  margin-right: auto;
  padding-right: var(--section-padding-pc2-maxWidth);
}
@media screen and (max-width: 768px) {
  .sectionWrap2-right {
    width: 100%;
    padding-right: var(--section-padding-sp);
  }
}

.sectionText, .faq_text1, .faq_textA, .faq_textA *, .textBlock_text, .form_privacy_check_label, .form_privacy_text, .form_item_label, .plan_li_bottom_text_span, .map_bottom_text_span2, .point_li_text, .feature_li_texts_text, .about_li_text, .footer_copyRight *, .templateText_text1, .templateText, .templateText * {
  font-size: 2rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 500;
}

.sectionEmphasis, .faq_link, .faq_singleLetter, .faq_textQ, .faq_textQ *, .supportCourse_row_text2, .supportCourse_row_text2 *, .supportCourse_row_text1, .plan_li_bottom_images_text, .plan_li_head_text, .map_back, .feature_manual_texts_text, .btn {
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.06em;
}

.sectionMidashi, .point_li_title {
  font-size: 3.2rem;
  font-weight: 900;
  line-height: 1.6;
  letter-spacing: 0.06em;
}

.sectionTitle, .faq .templateTitle2, .plan_li_head_text_span, .about_li_title, .FVSubPage_title {
  font-weight: 900;
  font-size: 4.8rem;
  line-height: 1.6;
  letter-spacing: 0.06em;
}

.sectionSection, .feature_manual_texts_title:not(:where(.-usage *)) {
  text-align: center;
  font-size: 6.4rem;
  line-height: 1.6;
  font-weight: 900;
  letter-spacing: 0.06em;
}
.sectionSection_span {
  line-height: 1.8;
  font-size: 2rem;
  letter-spacing: 0.06em;
  font-weight: bold;
  text-align: center;
  display: block;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.6rem;
}
.sectionSection_span::before, .sectionSection_span::after {
  content: "";
  display: inline-block;
  background-color: var(--color-gray);
  width: 6.4rem;
  height: 0.2rem;
}

.templateTitle {
  text-align: center;
  font-size: 6.4rem;
  line-height: 1.6;
  font-weight: 900;
  letter-spacing: 0.06em;
}
.templateTitle_span {
  line-height: 1.8;
  font-size: 2rem;
  letter-spacing: 0.06em;
  font-weight: bold;
  text-align: center;
  display: block;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
}
.templateTitle_span::before, .templateTitle_span::after {
  content: "";
  display: inline-block;
  background-color: var(--color-gray);
  width: 6.4rem;
  height: 0.2rem;
}
@media screen and (max-width: 768px) {
  .templateTitle {
    font-weight: 900;
    font-size: 4.8rem;
    line-height: 1.6;
    letter-spacing: 0.06em;
  }
}

.templateTitle2 {
  text-align: center;
  font-size: 6.4rem;
  line-height: 1.6;
  font-weight: 900;
  letter-spacing: 0.06em;
  color: var(--color-green);
  display: flex;
  align-items: center;
  border-left: solid 8px var(--color-green);
  padding-left: 2.4rem;
}
@media screen and (max-width: 768px) {
  .templateTitle2 {
    font-weight: 900;
    font-size: 4.8rem;
    line-height: 1.6;
    letter-spacing: 0.06em;
  }
}

.templateTitle3 {
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.06em;
  color: var(--color-green);
  border-left: solid 4px var(--color-green);
  padding-left: 1rem;
  margin-bottom: 2.4rem;
}

.templateText {
  border-bottom: solid 2px #D9D9D9;
  padding-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .templateText, .templateText * {
    letter-spacing: 0.1em;
  }
}
.templateText:not(:last-of-type) {
  margin-bottom: 3.2rem;
}
.templateOl_li {
  list-style: decimal;
  margin-left: 2.8rem;
}
.templateOl_li:not(:last-of-type) {
  margin-bottom: 3.3rem;
}
@media screen and (max-width: 768px) {
  .templateOl_li:not(:last-of-type) {
    margin-bottom: 3.55rem;
  }
}
.templateOl_li .dot {
  position: relative;
  display: inline-block;
}
.templateOl_li .dot::before {
  content: "・";
}

.header_inner {
  position: fixed;
  z-index: 100;
  top: 1.1rem;
  left: 1.5rem;
  right: 1.5rem;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .header_inner {
    justify-content: space-between;
    left: 0;
    right: 0;
    padding-left: 0.8rem;
    padding-right: 1.6rem;
    top: 1.6rem;
  }
}
.header_title {
  flex-shrink: 0;
}
.header_title_link {
  text-decoration: none;
  display: block;
  background-color: var(--color-white);
  position: relative;
  z-index: 0;
  border-radius: 100%;
  padding: 1.3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .header_title_link {
    padding: 0;
  }
}
.header_title_logo {
  display: block;
  width: 11.4rem;
  aspect-ratio: 1/1;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 768px) {
  .header_title_logo {
    width: 7.2rem;
  }
}
.header_nav {
  height: 10rem;
  padding-left: 1.4rem;
  position: relative;
  border-radius: 0 999px 999px 0;
  flex-shrink: 0;
  display: flex;
}
@media screen and (max-width: 768px) {
  .header_nav {
    height: initial;
  }
}
@media screen and (min-width: 769px) {
  .header_nav::before {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    height: 100%;
    width: 20rem;
    left: -10rem;
    top: 0;
    bottom: 0;
    background-color: var(--color-white);
  }
}
.header_nav_inner {
  display: flex;
  align-items: center;
}
.header_nav_inner * {
  font-family: var(--font-hiragino);
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  .header_nav {
    background-color: var(--color-white);
  }
}
.header_nav_ul {
  display: flex;
  padding-right: 1.2rem;
}
.header_nav_li {
  padding-inline: 3.9rem;
  height: 6.5rem;
  padding-bottom: 0.25rem;
}
.header_nav_li:first-of-type {
  padding-left: 3.2rem;
}
.header_nav_li:last-of-type {
  padding-right: 3.2rem;
}
.header_nav_li:not(:last-of-type) {
  border-right: dotted 0.05rem var(--color-text);
}
.header_nav_li_link {
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}
.header_nav_li_link:where(.-current *) * {
  color: var(--color-green);
}
.header_nav_li_link:hover {
  opacity: 0.7;
}
.header_nav_li_link:hover * {
  color: var(--color-green);
}
.header_nav_li_link:hover .header_nav_li_text::after {
  width: 2.4rem;
}
.header_nav_li_text {
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  line-height: 1.6;
  transition: all 0.3s;
  font-weight: 600;
  display: block;
  position: relative;
}
.header_nav_li_text::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  margin-inline: auto;
  bottom: -0.7rem;
  width: 0;
  height: 0.3rem;
  background-color: var(--color-green);
  transition: all 0.3s;
}
.header_nav_li_imageWrap {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 4rem;
  height: 4rem;
}
.header_nav_li_imageWrap:where(.-home *) {
  width: 4rem;
  height: 3.7rem;
}
.header_nav_li_imageWrap:where(.-feature *) {
  width: 4rem;
  height: 3.7rem;
}
.header_nav_li_imageWrap:where(.-fee *) {
  width: 3.5rem;
  height: 3.9rem;
}
.header_nav_line {
  height: 100%;
}
.header_nav_line_link {
  background-color: #06C755;
  display: flex;
  align-items: center;
  text-decoration: none;
  height: 100%;
  padding-inline: 0.9rem 2.7rem;
  border-radius: 0 999px 999px 0;
  transition: all 0.4s;
  border-left: solid 1px #06C755;
}
.header_nav_line_link * {
  color: var(--color-white);
}
.header_nav_line_link:hover {
  opacity: 0.6;
}
.header_nav_line_image {
  width: 5.5rem;
  -webkit-appearance: 1/1;
     -moz-appearance: 1/1;
          appearance: 1/1;
}
.header_nav_line_imageWrap {
  position: relative;
  left: 0.4rem;
}
.header_nav_line_text {
  font-size: 2rem;
  letter-spacing: 0.04em;
  line-height: 1.6;
  display: inline-block;
  position: relative;
  margin-right: 0.5rem;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 1.5rem;
  text-decoration-thickness: 0.05rem;
  position: relative;
  top: -0.3rem;
}
.header_nav_line_icon {
  position: relative;
  top: 0.3rem;
}
.header_nav_hamburger {
  width: 4rem;
  height: 2.9rem;
  position: relative;
}
.header_nav_hamburger:hover {
  cursor: pointer;
}
.header_nav_hamburger span {
  position: absolute;
  left: 0;
  right: 0;
  display: block;
  height: 0.3rem;
  width: 100%;
  background-color: var(--color-white);
  border-radius: 99px;
  transition: all 0.3s;
}
.header_nav_hamburger span:nth-of-type(1) {
  top: 0;
}
.header_nav_hamburger span:nth-of-type(2) {
  top: 50%;
  transform: translate(0, -50%);
}
.header_nav_hamburger span:nth-of-type(3) {
  bottom: 0;
}
.header_nav_hamburger span:where(.-active *) {
  background-color: var(--color-text);
  height: 0.15rem;
}
.header_nav_hamburger span:where(.-active *):nth-of-type(1) {
  top: 50%;
  transform: translate(0, -50%) rotate(45deg);
}
.header_nav_hamburger span:where(.-active *):nth-of-type(2) {
  top: 50%;
  transform: translate(0, -50%) rotate(225deg);
}
.header_nav_hamburger span:where(.-active *):nth-of-type(3) {
  bottom: initial;
  top: 50%;
  transform: translate(0, -50%) rotate(-45deg);
}
.header_nav_sp {
  position: fixed;
  inset: 0;
  background-color: white;
  z-index: -1;
  transform: translate(100%, 0);
  transition: all 0.3s;
  overflow-y: auto;
  padding-bottom: 4rem;
}
.header_nav_sp:where(.-active) {
  transform: none;
}
.header_nav_sp_inner {
  padding-top: 11.6rem;
  padding-inline: 2.4rem;
}
.header_nav_sp_ul {
  margin-bottom: 5.6rem;
}
.header_nav_sp_ul * {
  font-family: var(--font-hiragino);
  font-weight: 600;
}
.header_nav_sp_li_link {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 2.4rem;
  padding-left: 3.2rem;
  padding-block: 1.1rem;
  margin-block: 0.8rem;
  border-bottom: dotted 0.05rem var(--color-gray);
  position: relative;
}
.header_nav_sp_li_link:where(.-current *) * {
  color: var(--color-green);
}
.header_nav_sp_li_link:where(.-current *)::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0.8rem;
  transform: translate(0, -50%);
  width: 0.3rem;
  height: 0;
  background-color: var(--color-green);
  height: 3.2rem;
}
.header_nav_sp_li_text {
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: var(--color-black);
  font-weight: 600;
}

.footer {
  margin-top: 15rem;
}
.footer:where(.page-access *) {
  margin-top: 18rem;
}
@media screen and (max-width: 768px) {
  .footer {
    margin-top: 8rem;
  }
}
.footer_inner {
  padding-top: 47.1rem;
  background-image: url("../img/footer_back.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top;
  padding-inline: 18.3rem;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .footer_inner {
    padding-top: 24.1rem;
    padding-inline: 2.4rem;
    background-image: url("../img/footer_back-sp.webp");
  }
}
.footer_head {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6.4rem;
  margin-bottom: 11.1rem;
}
.footer_head * {
  font-family: var(--font-hiragino);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .footer_head {
    flex-direction: column;
    margin-bottom: 6.4rem;
  }
}
.footer_head_logo {
  width: 14.3rem;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 768px) {
  .footer_head_logo {
    width: 14.3rem;
  }
}
.footer_head_text {
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: var(--color-white);
  font-weight: 600;
}
.footer_body {
  padding-bottom: 12.6rem;
}
.footer_body * {
  font-family: var(--font-hiragino);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .footer_body {
    padding-bottom: 7.9rem;
  }
}
.footer_ul {
  display: flex;
  justify-content: center;
  margin-bottom: 11rem;
}
@media screen and (max-width: 768px) {
  .footer_ul {
    flex-direction: column;
    margin-bottom: 6rem;
  }
}
@media screen and (min-width: 769px) {
  .footer_li:not(:last-of-type) .footer_li_link {
    border-right: dotted 0.2rem var(--color-white);
  }
}
@media screen and (min-width: 769px) {
  .footer_li:first-of-type .footer_li_link {
    padding-left: 0;
  }
}
@media screen and (min-width: 769px) {
  .footer_li:last-of-type .footer_li_link {
    padding-right: 0;
  }
}
@media screen and (max-width: 768px) {
  .footer_li:last-of-type .footer_li_link {
    border-bottom: none;
  }
}
.footer_li_link {
  text-decoration: none;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  gap: 0 0.8rem;
  padding-inline: 3rem;
}
@media screen and (max-width: 768px) {
  .footer_li_link {
    padding-left: 4rem;
    padding-block: 2.3rem;
    border-bottom: dotted 2px var(--color-white);
  }
}
.footer_li_link:hover {
  cursor: pointer;
  opacity: 0.7;
}
.footer_li_image {
  width: 1.4rem;
  height: 1.4rem;
  position: relative;
  bottom: 0.2rem;
}
.footer_li_text {
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: var(--color-white);
  font-weight: 600;
}
.footer_link {
  display: flex;
  text-decoration: none;
  gap: 0 0.8rem;
  color: var(--color-white);
  transition: all 0.3s;
}
.footer_links {
  display: flex;
  justify-content: center;
  gap: 0 6.4rem;
  border-top: solid 1px var(--color-white);
  border-bottom: solid 1px var(--color-white);
  padding-block: 2.4rem;
}
.footer_link:hover {
  cursor: pointer;
  opacity: 0.7;
}
.footer_link_image {
  width: 0.8rem;
  height: 0.7rem;
  -o-object-fit: contain;
     object-fit: contain;
  position: relative;
  top: -0.15rem;
}
.footer_link_text {
  font-size: 1.6rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: var(--color-white);
  font-weight: 600;
}
.footer_bottom {
  background-color: var(--color-black);
  height: 6.4rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .footer_bottom {
    height: 4.9rem;
  }
}
.footer_copyRight * {
  color: var(--color-white);
}
@media screen and (max-width: 768px) {
  .footer_copyRight * {
    font-size: 1.4rem;
  }
}
.footer_back_text {
  position: absolute;
  width: 44rem;
  top: 0;
  left: 24rem;
  transform: translate(-80rem, 0) rotate3d(0, 1, 0, 80deg);
}
.footer_back_text:where(.-active *) {
  -webkit-animation: ballRotateIn 5s ease-out forwards;
          animation: ballRotateIn 5s ease-out forwards;
}
@media screen and (max-width: 768px) {
  .footer_back_text {
    width: 20rem;
    left: -1.3rem;
  }
}
.footer_back_ball {
  position: absolute;
  z-index: 1;
  width: 5.1rem;
  top: 35%;
  right: 13.5%;
  opacity: 0;
}
.footer_back_ball:where(.-active *) {
  -webkit-animation: golfBallPath 5s linear forwards;
          animation: golfBallPath 5s linear forwards;
}
@media screen and (max-width: 768px) {
  .footer_back_ball {
    width: 2.2rem;
  }
  .footer_back_ball:where(.-active *) {
    -webkit-animation: golfBallPath-sp 5s linear forwards;
            animation: golfBallPath-sp 5s linear forwards;
  }
}

@-webkit-keyframes golfBallPath {
  /* スタート */
  0% {
    top: 35%;
    right: 13.5%;
    opacity: 0;
  }
  5% {
    top: 35%;
    right: 13.5%;
    opacity: 1;
  }
  /* 直線 */
  57% {
    top: 21.3%;
    right: 48.5%;
    opacity: 1;
  }
  /* ここからホールへ沈む */
  60% {
    top: 22.1%;
    right: 48.5%;
    opacity: 1;
  }
  /* 中間 */
  /* 完全に見えなくなる（全カット） */
  70%, 100% {
    top: 23.1%;
    right: 48.5%;
    opacity: 0;
  }
}

@keyframes golfBallPath {
  /* スタート */
  0% {
    top: 35%;
    right: 13.5%;
    opacity: 0;
  }
  5% {
    top: 35%;
    right: 13.5%;
    opacity: 1;
  }
  /* 直線 */
  57% {
    top: 21.3%;
    right: 48.5%;
    opacity: 1;
  }
  /* ここからホールへ沈む */
  60% {
    top: 22.1%;
    right: 48.5%;
    opacity: 1;
  }
  /* 中間 */
  /* 完全に見えなくなる（全カット） */
  70%, 100% {
    top: 23.1%;
    right: 48.5%;
    opacity: 0;
  }
}
@-webkit-keyframes golfBallPath-sp {
  /* スタート */
  0% {
    top: 16rem;
    right: 9.5%;
    opacity: 0;
  }
  5% {
    top: 16rem;
    right: 9.5%;
    opacity: 1;
  }
  /* 直線 */
  57% {
    top: 10.5rem;
    right: 20.3rem;
    opacity: 1;
  }
  /* ここからホールへ沈む */
  /* 完全に見えなくなる（全カット） */
  70%, 100% {
    top: 12rem;
    right: 20.3rem;
    opacity: 0;
  }
}
@keyframes golfBallPath-sp {
  /* スタート */
  0% {
    top: 16rem;
    right: 9.5%;
    opacity: 0;
  }
  5% {
    top: 16rem;
    right: 9.5%;
    opacity: 1;
  }
  /* 直線 */
  57% {
    top: 10.5rem;
    right: 20.3rem;
    opacity: 1;
  }
  /* ここからホールへ沈む */
  /* 完全に見えなくなる（全カット） */
  70%, 100% {
    top: 12rem;
    right: 20.3rem;
    opacity: 0;
  }
}
@-webkit-keyframes ballRotateIn {
  0% {
    transform: translate(-80rem, 0) rotate3d(0, 1, 0, 80deg);
  }
  51% {
    transform: translate(-80rem, 0) rotate3d(0, 1, 0, 80deg);
  }
  73%, 100% {
    transform: translate(0, 0) rotate3d(0, 1, 0, 0deg);
  }
}
@keyframes ballRotateIn {
  0% {
    transform: translate(-80rem, 0) rotate3d(0, 1, 0, 80deg);
  }
  51% {
    transform: translate(-80rem, 0) rotate3d(0, 1, 0, 80deg);
  }
  73%, 100% {
    transform: translate(0, 0) rotate3d(0, 1, 0, 0deg);
  }
}
/* 使用例 */
.ball {
  position: absolute;
  top: 0;
  left: 23rem;
  transform: rotate3d(0, 1, 0, 90deg);
  -webkit-animation: ballRotateIn 5s ease forwards;
          animation: ballRotateIn 5s ease forwards;
}

@media screen and (min-width: 769px) {
  .reservation:where(.page-access *) {
    margin-bottom: 11.5rem;
  }
}
.reservation .templateTitle {
  margin-bottom: 7.3rem;
}
@media screen and (max-width: 768px) {
  .reservation .templateTitle {
    margin-bottom: 8rem;
    line-height: 1.5;
  }
}
.reservation_line {
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  .reservation_line {
    margin-bottom: 1.2rem;
  }
}
.reservation_line_link {
  text-decoration: none;
}
.reservation_line_texts {
  width: 100%;
  background-color: var(--color-green-light);
  border: solid 2px var(--color-green);
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: 6.2rem;
  transition: all 0.3s;
}
.reservation_line_texts:hover {
  background-color: var(--color-white);
  color: var(--color-green-light);
}
.reservation_line_texts:hover .reservation_line_texts_text, .reservation_line_texts:hover .reservation_line_texts_text * {
  color: var(--color-green-light);
}
.reservation_line_texts:hover .reservation_line_texts_text, .reservation_line_texts:hover .reservation_line_texts_icon * {
  color: var(--color-green-light);
}
.reservation_line_texts_image {
  margin-right: 1.6rem;
  width: 9.4rem;
  aspect-ratio: 1/1;
}
.reservation_line_texts_text {
  font-size: 4.4rem;
  font-weight: bold;
  color: white;
  letter-spacing: 0.24em;
}
.reservation_line_texts_text, .reservation_line_texts_text* {
  transition: all 0.3s;
  line-height: 1.6;
  letter-spacing: 0.16em;
}
.reservation_line_texts_text_span {
  font-size: 4.8rem;
  text-decoration: underline;
  -webkit-text-decoration-color: var(--color-yellow);
          text-decoration-color: var(--color-yellow);
  text-underline-offset: 1.3rem;
}
.reservation_line_texts_icon {
  width: 3rem;
  aspect-ratio: 24/21;
  max-width: initial;
  max-height: initial;
  -o-object-fit: contain;
     object-fit: contain;
  position: relative;
  top: 0.5rem;
  transition: all 0.3s;
}
.reservation_line_texts_icon, .reservation_line_texts_icon * {
  color: var(--color-white);
}
.reservation_btn {
  width: calc((100% - 1.6rem) / 2);
}
.reservation_btns {
  display: flex;
  gap: 1.6rem;
}
@media screen and (max-width: 768px) {
  .reservation_btns {
    flex-direction: column;
  }
}
@media screen and (max-width: 768px) {
  .reservation_btn {
    width: 100%;
  }
}
.reservation_btn_link {
  text-decoration: none;
  padding-block: 6.3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.4rem 0.8rem;
  flex-wrap: wrap;
  border: solid 0.4rem var(--color-green-light);
  border-radius: 999px;
  overflow: hidden;
  transition: all 0.3s;
}
@media screen and (max-width: 768px) {
  .reservation_btn_link {
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 0;
    padding: 1.6rem 1.2rem;
    padding-right: 0.8rem;
  }
}
.reservation_btn_link:hover {
  background-color: var(--color-green-light);
}
.reservation_btn_link:hover * {
  color: var(--color-white);
}
.reservation_btn_image {
  -o-object-fit: contain;
     object-fit: contain;
  transition: all 0.3s;
  width: 100%;
  height: 100%;
}
.reservation_btn_imageWrap {
  display: flex;
  align-items: center;
  height: 6.4rem;
  width: 100%;
}
.reservation_btn_imageWrap:where(.-contact *) {
  position: relative;
}
@media screen and (min-width: 769px) {
  .reservation_btn_imageWrap:where(.-contact *) {
    top: -0.8rem;
  }
}
@media screen and (max-width: 768px) {
  .reservation_btn_imageWrap {
    width: 3.2rem;
    height: 3.2rem;
  }
}
@media screen and (min-width: 769px) {
  .reservation_btn_image:where(.-contact *) {
    height: 5.1rem;
  }
}
.reservation_btn_image, .reservation_btn_image * {
  color: var(--color-green-light);
}
.reservation_btn_text {
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.04em;
  position: relative;
  top: -0.4rem;
  color: var(--color-green-light);
  transition: all 0.3s;
}
@media screen and (max-width: 768px) {
  .reservation_btn_text {
    font-size: 2.4rem;
  }
}
.reservation_btn_icon {
  transition: all 0.3s;
  width: 2.88rem;
  height: 2.52rem;
}
.reservation_btn_icon, .reservation_btn_icon * {
  color: var(--color-green-light);
}

.btn {
  border: solid 2px var(--color-green);
  border-radius: 999px;
  color: var(--color-green);
  padding-block: 1.8rem;
  display: inline-block;
  width: 55rem;
  margin-inline: auto;
  background-color: transparent;
  transition: all 0.3s;
  text-decoration: none;
}
.btnWrap {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .btn {
    padding-block: 2rem;
    width: 100%;
  }
}
.btn:hover {
  background-color: var(--color-green);
  color: var(--color-white);
}

/* ----- スライダー ----- */
.slick-track {
  display: flex !important;
}

.slick-list {
  overflow: hidden;
  padding-inline: 0 !important;
}

.slick-slide {
  height: auto !important;
}

* {
  min-width: 0;
  min-height: 0;
}

.slick-dots {
  bottom: -4rem !important;
}
.slick-dots:where(.page-top *) {
  transform: translate(-2.4rem, 0) !important;
}

.slick-dots li {
  width: 1.6rem !important;
  margin-inline: 0 !important;
}

.slick-dots li button {
  padding: 0 !important;
  background-color: var(--color-white) !important;
  border-radius: 99px !important;
  width: 0.8rem !important;
  height: 0.8rem !important;
  margin-inline: auto !important;
}
.slick-dots li button:where(.page-fee *) {
  border: solid 0.5px var(--color-green-light) !important;
}

.slick-dots li.slick-active button {
  width: 2.4rem !important;
  background-color: var(--color-green-dark) !important;
}

.slick-dots li button:before {
  width: 0.8rem !important;
  color: var(--color-white) !important;
  opacity: initial !important;
  padding-left: 0.4rem !important;
  display: none !important;
}

.slick-dots li.slick-active {
  width: 3.2rem !important;
  padding-inline: 0 !important;
}

.slick-dots li.slick-active button:before {
  content: "";
  width: 2.4rem !important;
  display: block;
  height: 0.8rem;
  background-color: var(--color-green-dark);
  border-radius: 99px;
  position: relative;
  top: 0.25rem;
}

.slider_arrows .slider_arrow {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s;
}

.slider_arrows .slider_arrow.slick-arrow {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.slider_arrows .slider_arrow.slick-disabled {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.slick-dotted.slick-slider {
  margin-bottom: 0 !important;
}

.slider_ul {
  margin-bottom: 100px;
}
.slider_ulWrap {
  position: relative;
}
.slider_arrow {
  width: 4rem;
  height: 4rem;
  background-image: url("../img/slick_arrow-white.webp");
  background-repeat: no-repeat;
  background-size: contain;
}
.slider_arrows {
  position: absolute;
  left: 0;
  right: 0;
  top: 38%;
  transform: translate(0, -50%);
  display: flex;
  justify-content: space-between;
}
.slider_arrows:where(.point *) {
  top: 51.5%;
}
@media screen and (max-width: 768px) {
  .slider_arrows:where(.point *) {
    top: 52.2%;
  }
}
.slider_arrows:where(.plan *) {
  top: 53%;
  right: -1.7%;
  left: -1.7%;
}
.slider_arrow:where(.point *, .plan *) {
  background-image: url("../img/slick_arrow-green.webp");
}
.slider_arrow.-prev {
  transform: rotate(180deg);
}
.FVSubPage:not(.page-feature *) {
  margin-bottom: 12rem;
}
@media screen and (max-width: 768px) {
  .FVSubPage:not(:where(.page-feature *)) {
    margin-bottom: 8rem;
  }
  .FVSubPage:where(.page-privacy_policy *) {
    margin-bottom: 5.1rem;
  }
  .FVSubPage:where(.page-feature *) {
    margin-bottom: 0;
  }
}
.FVSubPage_inner {
  position: relative;
}
.FVSubPage_title {
  position: absolute;
  top: 24.3rem;
  left: 12rem;
  color: var(--color-white);
}
@media screen and (max-width: 768px) {
  .FVSubPage_title {
    top: 15rem;
    left: 5.6rem;
    border-radius: 0 0 2.4rem 2.4rem;
    letter-spacing: 0;
  }
  .FVSubPage_title:where(.page-fee *, .page-privacy_policy *) {
    top: 12rem;
  }
}
.FVSubPage_image {
  width: 100%;
}

/* 共通部ここまで
---------- ---------- */
/* ========== ========== ==========
アニメーション
========== ========== ========== */
/* ----- ホバー ----- */
@media screen and (min-width: 768px) {
  .css-hover {
    transition: all 0.3s;
  }
  .css-hover:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}
/* ----- ズーム付のホバー ----- */
@media screen and (min-width: 768px) {
  .css-hover-zoom {
    transition: all 0.5s;
  }
  .css-hover-zoom:hover {
    transform: scale(1.08);
  }
}
/* ----- フェードイン ----- */
.js-fadeIn {
  opacity: 0;
  transform: translate(0, 100px);
  transition: all 0.7s;
}

.js-fadeIn.-active {
  opacity: 1;
  transform: translate(0, 0);
}

/* ----- ぼかしが消えながらフェードイン ----- */
.js-fadeIn-blurry {
  overflow: hidden;
}
.js-fadeIn-blurry:not(:has(.animation)), .js-fadeIn-blurry .animation {
  opacity: 0;
  transition: all 1s;
  filter: blur(100px);
}

.js-fadeIn-blurry.-active:not(:has(.animation)), .js-fadeIn-blurry.-active .animation {
  opacity: 1;
  -webkit-animation: animation-blurry 1s ease-in forwards;
          animation: animation-blurry 1s ease-in forwards;
}

@-webkit-keyframes animation-blurry {
  0% {
    filter: blur(5px);
    transform: scale(1.02);
  }
  100% {
    filter: blur(0);
    transform: scale(1);
  }
}

@keyframes animation-blurry {
  0% {
    filter: blur(5px);
    transform: scale(1.02);
  }
  100% {
    filter: blur(0);
    transform: scale(1);
  }
}
/* ----- 左から徐々に見えるようになるフェードイン ----- */
.js-fadeIn-fromLeft {
  opacity: 0;
}

.js-fadeIn-fromLeft.-active {
  -webkit-animation: js-fadeIn-fromLeft 0.7s ease-out forwards;
          animation: js-fadeIn-fromLeft 0.7s ease-out forwards;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

@-webkit-keyframes js-fadeIn-fromLeft {
  0% {
    -webkit-clip-path: inset(-100% 100% -100% 0);
            clip-path: inset(-100% 100% -100% 0);
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(-100% 0 -100% 0);
            clip-path: inset(-100% 0 -100% 0);
    opacity: 1;
  }
}

@keyframes js-fadeIn-fromLeft {
  0% {
    -webkit-clip-path: inset(-100% 100% -100% 0);
            clip-path: inset(-100% 100% -100% 0);
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(-100% 0 -100% 0);
            clip-path: inset(-100% 0 -100% 0);
    opacity: 1;
  }
}
/* ----- 右から徐々に見えるようになるフェードイン ----- */
.js-fadeIn-fromRight {
  opacity: 0;
}

.js-fadeIn-fromRight.-active {
  -webkit-animation: js-fadeIn-fromRight 0.7s ease-out forwards;
          animation: js-fadeIn-fromRight 0.7s ease-out forwards;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

@-webkit-keyframes js-fadeIn-fromRight {
  0% {
    -webkit-clip-path: inset(-100% 0 -100% 100%);
            clip-path: inset(-100% 0 -100% 100%);
    /* 左100%カット → 右から徐々に見える */
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(-100% 0 -100% 0);
            clip-path: inset(-100% 0 -100% 0);
    /* 全表示 */
    opacity: 1;
  }
}

@keyframes js-fadeIn-fromRight {
  0% {
    -webkit-clip-path: inset(-100% 0 -100% 100%);
            clip-path: inset(-100% 0 -100% 100%);
    /* 左100%カット → 右から徐々に見える */
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(-100% 0 -100% 0);
            clip-path: inset(-100% 0 -100% 0);
    /* 全表示 */
    opacity: 1;
  }
}
/* ----- 遅延 ----- */
.css-delay03 {
  transition-delay: 0.3s !important;
}

.css-delay06 {
  transition-delay: 0.6s !important;
}

/* アニメーション
---------- ---------- */
/* ========== ========== ==========
トップページ
========== ========== ========== */
.FV {
  margin-bottom: 16rem;
}
@media screen and (max-width: 768px) {
  .FV {
    margin-bottom: 8rem;
  }
}
.FV_inner {
  position: relative;
  border-radius: 0 0 4rem 4rem;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .FV_inner {
    border-radius: 0 0 2.4rem 2.4rem;
  }
}
.FV_line {
  width: 36.4rem;
  aspect-ratio: 1/1;
  -o-object-fit: contain;
     object-fit: contain;
  transition: all 0.3s;
  position: relative;
  right: -6.8rem;
  bottom: -6.8rem;
}
.FV_lineWrap {
  position: absolute;
  bottom: 0;
  right: 0;
}
.FV_line:hover {
  cursor: pointer;
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  .FV_line {
    width: 26rem;
    right: -4.8rem;
    bottom: -5rem;
  }
}
.FV_texts {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 28.5rem;
}
@media screen and (max-width: 768px) {
  .FV_texts {
    margin-top: 19.7rem;
    left: 2.7rem;
    width: 38.2rem;
  }
}
.FV_texts_image {
  width: 76.1rem;
  display: inline-block;
}
.FV_text1 {
  font-size: 4.8rem;
  color: var(--color-white);
  position: relative;
  z-index: 0;
  font-weight: bold;
  text-align: center;
  font-family: var(--font-hiragino);
}
@media screen and (max-width: 768px) {
  .FV_text1 {
    font-size: 4.2rem;
  }
}
.FV_text1, .FV_text1 * {
  letter-spacing: 0.06em;
  line-height: 1.6;
}
.FV_text1_dummy {
  position: absolute;
  z-index: -1;
  inset: 0;
  -webkit-text-stroke: 1rem var(--color-green);
  font-family: var(--font-hiragino);
}
.FV_text2 {
  font-size: 10.4rem;
  color: var(--color-yellow);
  position: relative;
  font-weight: bold;
  z-index: 0;
  text-align: center;
  font-family: var(--font-hiragino);
}
@media screen and (max-width: 768px) {
  .FV_text2 {
    font-size: 9.1rem;
  }
}
.FV_text2, .FV_text2 * {
  letter-spacing: 0.04em;
  font-style: italic;
  line-height: 1.6;
}
.FV_text2_dummy {
  position: absolute;
  z-index: -1;
  inset: 0;
  -webkit-text-stroke: 1.8rem var(--color-green);
  font-family: var(--font-hiragino);
}

.about {
  margin-bottom: 16rem;
  overflow: hidden;
}
.about:where(.page-feature *) {
  padding-top: 12rem;
  margin-bottom: 12rem;
}
@media screen and (max-width: 768px) {
  .about:where(.page-feature *) {
    padding-top: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .about {
    margin-bottom: 8rem;
  }
}
.about .templateTitle {
  margin-bottom: 19.5rem;
}
@media screen and (max-width: 768px) {
  .about .templateTitle {
    margin-bottom: 6.4rem;
  }
}
.about_ul {
  width: 100%;
}
.about_li {
  display: flex;
  justify-content: space-between;
  overflow: visible;
  padding-left: 10.4rem;
}
.about_li:not(:last-of-type) {
  margin-bottom: 20rem;
}
@media screen and (max-width: 768px) {
  .about_li:not(:last-of-type) {
    margin-bottom: 8rem;
  }
}
.about_li:where(.-reverse) {
  padding-left: 0;
  padding-right: 7.1rem;
  flex-direction: row-reverse;
}
.about_li:where(.-reverse):where(.page-feature *) {
  padding-right: 9rem;
}
@media screen and (max-width: 768px) {
  .about_li {
    flex-direction: column-reverse;
    padding-inline: 0;
    gap: 6.4rem;
  }
  .about_li:where(.page-feature *) {
    flex-direction: column;
  }
}
.about_li_title {
  color: var(--color-green);
  position: relative;
  margin-bottom: 4.2rem;
  z-index: 0;
  margin-top: 2.5rem;
}
.about_li_title:where(.-n01 *) {
  margin-top: 6.4rem;
}
@media screen and (max-width: 768px) {
  .about_li_title {
    margin-top: 0;
    font-size: 4.4rem;
    letter-spacing: 0.06em;
  }
}
.about_li_title::before {
  content: "";
  display: block;
  position: absolute;
  left: -5.2rem;
  top: -4rem;
  z-index: -1;
  background-image: url("../img/about_icon_ball.webp");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 12rem;
  aspect-ratio: 120/116;
}
.about_li_title::after {
  content: "";
  display: block;
  position: absolute;
  top: -15.7rem;
  right: -14.2rem;
  z-index: -1;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 28.5rem;
  aspect-ratio: 285/314;
}
@media screen and (max-width: 768px) {
  .about_li_title::after {
    width: 18.2rem;
    top: -4.6rem;
    right: -2.4rem;
  }
}
.about_li:where(.page-top *):nth-of-type(1) .about_li_title::after {
  background-image: url("../img/about_icon_number_1.webp");
}
.about_li:where(.page-top *):nth-of-type(2) .about_li_title::after {
  background-image: url("../img/about_icon_number_2.webp");
  right: -8rem;
}
@media screen and (max-width: 768px) {
  .about_li:where(.page-top *):nth-of-type(2) .about_li_title::after {
    right: -2.4rem;
  }
}
.about_li:where(.page-top *):nth-of-type(3) .about_li_title::after {
  background-image: url("../img/about_icon_number_3.webp");
}
.about_li_text {
  max-width: 48rem;
}
@media screen and (max-width: 768px) {
  .about_li_texts {
    margin-inline: 2.4rem;
  }
}
.about_li_text:where(.-reverse *) {
  margin-left: 0.5rem;
}
@media screen and (max-width: 768px) {
  .about_li_text:where(.-reverse *) {
    margin-left: 0;
  }
}
.about_li_imageWrap {
  width: 79rem;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .about_li_imageWrap {
    width: 100%;
  }
}

.feature {
  overflow: hidden;
  border: 8rem;
  background-image: url("../img/feature_back.webp");
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  padding-top: 20rem;
  border-radius: 8rem;
  margin-bottom: 18rem;
}
@media screen and (max-width: 768px) {
  .feature {
    margin-bottom: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .feature {
    background-image: url("../img/feature_back-sp.webp");
    border-radius: 2.4rem;
    padding-top: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .feature .sectionWrap {
    padding: 0;
  }
}
.feature .templateTitle {
  color: var(--color-white);
  margin-bottom: 12rem;
}
@media screen and (max-width: 768px) {
  .feature .templateTitle {
    margin-bottom: 6.4rem;
  }
}
.feature .templateTitle_span::before, .feature .templateTitle_span::after {
  background-color: var(--color-white);
}
.feature_ulWrap {
  position: relative;
  margin-bottom: 20rem;
}
@media screen and (max-width: 768px) {
  .feature_ulWrap {
    margin-bottom: 10rem;
  }
}
@media screen and (min-width: 769px) {
  .feature_ul {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .feature_ul {
    padding-left: 2.4rem;
  }
}
@media screen and (min-width: 769px) {
  .feature_li {
    width: calc((100% - 2.4rem) / 2);
  }
}
@media screen and (max-width: 768px) {
  .feature_li {
    padding-inline: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .feature_li:first-of-type {
    padding-left: 0;
  }
}
.feature_li_inner {
  overflow: hidden;
  border-radius: 2.4rem;
  background-color: var(--color-white);
}
.feature_li_image {
  height: 26.8rem;
  width: 100%;
}
.feature_li_texts {
  padding: 2.4rem 4rem 3.2rem;
  min-height: 19.2rem;
}
.feature_li_texts_title {
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.8;
  color: var(--color-green);
  flex-shrink: 0;
}
.feature_li_texts_titleWrap {
  display: flex;
  align-items: center;
  gap: 1.6rem;
  margin-bottom: 1.6rem;
}
.feature_li_texts_titleWrap::after {
  content: "";
  display: block;
  height: 0.1rem;
  width: 100%;
  background-color: var(--color-green);
}
.feature_manual {
  width: 100%;
  position: relative;
}
.feature_manual:nth-of-type(1) {
  border-radius: 8rem 8rem 0 0;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .feature_manual:nth-of-type(1) {
    border-radius: 2.4rem 2.4rem 0 0;
  }
}
.feature_manual_texts {
  position: absolute;
  top: 48%;
  left: 0;
  right: 0;
  transform: translate(0, -50%);
  padding-inline: 16rem;
}
@media screen and (max-width: 768px) {
  .feature_manual_texts {
    top: 50%;
    padding-inline: 1.9rem;
  }
}
.feature_manual_texts_text {
  color: var(--color-white);
}
.feature_manual_texts_title {
  color: var(--color-white);
  text-align: left;
  margin-bottom: 10rem;
}
@media screen and (max-width: 768px) {
  .feature_manual_texts_title {
    font-size: 4.8rem;
    font-weight: 900;
    line-height: 1.4;
    letter-spacing: 0.06em;
  }
}
.feature_manual_texts_title:where(.-usage *) {
  font-size: 6.4rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  .feature_manual_texts_title:where(.-usage *) {
    font-size: 4.8rem;
    font-weight: 900;
    line-height: 1.4;
    letter-spacing: 0;
  }
}
.feature_manual_texts_link {
  text-decoration: none;
  padding: 2.4rem 8.8rem;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  background-color: var(--color-white);
  color: var(--color-green);
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  transition: all 0.3s;
  font-weight: bold;
  font-family: var(--font-hiragino);
}
@media screen and (max-width: 768px) {
  .feature_manual_texts_link {
    width: 100%;
    text-align: center;
    padding-block: 1.6rem;
  }
}
.feature_manual_texts_link:hover {
  color: var(--color-white);
  background-color: var(--color-green);
}
.feature_manual_backWrap {
  width: 100%;
}

/* トップページここまで
---------- ---------- */
/* ========== ========== ==========
特徴ページここから
========== ========== ========== */
.point {
  background-image: url("../img/point_back.webp");
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 8rem;
  padding: 20rem 10.4rem;
  margin-bottom: 19rem;
}
@media screen and (max-width: 768px) {
  .point {
    background-image: url("../img/point_back-sp.webp");
    border-radius: 2.4rem;
    margin-bottom: 8rem;
    padding: 8rem 0 11.2rem;
  }
}
.point .templateTitle {
  color: var(--color-white);
  margin-bottom: 12rem;
}
@media screen and (max-width: 768px) {
  .point .templateTitle {
    margin-bottom: 6.4rem;
    line-height: 1.1;
    letter-spacing: 0;
  }
}
.point .templateTitle_span::before, .point .templateTitle_span::after {
  background-color: var(--color-white);
}
.point_ul {
  display: flex;
  gap: 0.8rem;
}
.point_ulWrap {
  position: relative;
}
.point_li {
  background-color: var(--color-white);
  border-radius: 2.4rem;
  padding: 2.2rem 2rem 3.2rem;
  border: solid 4px var(--color-green-light);
  width: calc((100% - 1.6rem) / 3);
}
@media screen and (max-width: 768px) {
  .point_li {
    padding-top: 2.4rem;
    padding-bottom: 4.2rem;
    width: 100%;
    margin-inline: 0.8rem;
  }
}
.point_li_number {
  display: block;
  width: 10.9rem;
  margin-inline: auto;
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 768px) {
  .point_li_number {
    width: 10.9rem;
  }
}
.point_li_image {
  display: block;
  width: 16rem;
  height: 16rem;
  margin-inline: auto;
  margin-bottom: 2.4rem;
}
.point_li_image:where(.-n01 *) {
  margin-bottom: 2rem;
}
@media screen and (max-width: 768px) {
  .point_li_image {
    width: 8rem;
    height: 8rem;
  }
}
.point_li_title {
  height: 10.2rem;
  color: var(--color-green-light);
  margin-bottom: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* 特徴ページここまで
---------- ---------- */
/* ========== ========== ==========
アクセスページここから
========== ========== ========== */
.map {
  margin-bottom: 19rem;
}
@media screen and (max-width: 768px) {
  .map {
    margin-bottom: 16rem;
  }
}
@media screen and (max-width: 768px) {
  .map .sectionWrap:has(.map_image) {
    padding-inline: 0;
  }
}
@media screen and (max-width: 768px) {
  .map .templateTitle2 {
    margin-bottom: 3.2rem;
  }
}
.map_head {
  display: flex;
  align-items: center;
  gap: 7.25rem;
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .map_head {
    display: block;
  }
}
.map_head_text1, .map_head_text2 {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  line-height: 1.8;
  color: var(--color-black);
}
@media screen and (max-width: 768px) {
  .map_head_text1, .map_head_text2 {
    font-size: 1.9rem;
    padding-inline: 1.6rem;
  }
}
.map_head_text1 {
  margin-bottom: 0.4rem;
}
.map_image {
  width: 100%;
  height: 64rem;
  margin-bottom: 4.5rem;
  display: block;
}
.map_bottom_text {
  margin-bottom: 4.8rem;
}
.map_bottom_text_span1 {
  display: block;
  font-size: 2.4rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: 900;
}
.map_link {
  background-color: var(--color-green-light);
  border: solid 2px var(--color-green-light);
  border-radius: 0.8rem;
  display: flex;
  gap: 0.8rem;
  align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  padding: 1.6rem 2.4rem;
  text-decoration: none;
}
.map_link:hover {
  background-color: var(--color-white);
}
@media screen and (max-width: 768px) {
  .map_link {
    margin-bottom: 14.4rem;
  }
}
.map_link_text {
  color: var(--color-white);
  font-size: 2.4rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  font-weight: bold;
  transition: all 0.3s;
}
.map_link:hover .map_link_text {
  color: var(--color-green-light);
}
.map_link_arrow, .map_link_link {
  -o-object-fit: contain;
     object-fit: contain;
  margin-top: 0.3rem;
  transition: all 0.3s;
}
.map_link_arrow *, .map_link_link * {
  color: var(--color-white);
}
.map_link:hover .map_link_arrow *, .map_link:hover .map_link_link * {
  color: var(--color-green-light);
}
.map_link_arrow {
  width: 1.4rem;
  height: 1.6rem;
}
.map_link_link {
  width: 1.8rem;
  height: 1.8rem;
}
.map_back {
  display: inline-block;
  border: solid 2px var(--color-green);
  border-radius: 999px;
  color: var(--color-green);
  padding-block: 2rem;
  width: 100%;
  text-align: center;
  text-decoration: none;
}
.map_back_span1 {
  margin-right: 1.5rem;
}

/* アクセスページここまで
---------- ---------- */
/* ========== ========== ==========
料金ページここから
========== ========== ========== */
.plan {
  margin-bottom: 11rem;
}
@media screen and (max-width: 768px) {
  .plan .sectionWrap {
    padding-inline: 0.8rem;
  }
}
.plan_ul {
  display: flex;
  gap: 0 2.4rem;
}
.plan_ulWrap {
  position: relative;
}
.plan_li {
  border: solid 2px var(--color-green);
  border-radius: 2.4rem;
  padding: 3.2rem 3.2rem 4.8rem;
}
@media screen and (max-width: 768px) {
  .plan_li {
    padding: 3rem 1.6rem;
  }
}
.plan_li_head {
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .plan_li_head {
    margin-bottom: 2.4rem;
  }
}
.plan_li_head_text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 3.2rem;
  padding-left: 1.6rem;
  color: var(--color-green);
}
@media screen and (max-width: 768px) {
  .plan_li_head_text {
    flex-direction: column;
    align-items: flex-start;
  }
}
.plan_li_image {
  border-radius: 2.4rem;
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .plan_li_image {
    margin-bottom: 2.4rem;
    aspect-ratio: 382/260;
  }
}
@media screen and (max-width: 768px) {
  .plan_li_bottom {
    margin-left: 1.6rem;
  }
}
.plan_li_bottom_text {
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.06em;
  color: var(--color-green);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 3.2rem;
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .plan_li_bottom_text {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 2.4rem;
  }
}
.plan_li_bottom_images {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 3.2rem;
}
@media screen and (max-width: 768px) {
  .plan_li_bottom_images {
    justify-content: flex-start;
  }
}
.plan_li_bottom_images_text {
  color: var(--color-green);
}

.flow {
  background-image: url("../img/flow_back.webp");
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 8rem;
  padding: 19rem 10.4rem;
  margin-bottom: 20rem;
}
@media screen and (max-width: 768px) {
  .flow {
    background-image: url("../img/flow_back-sp.webp");
    border-radius: 2.4rem;
    margin-bottom: 8rem;
    padding: 9rem 2.4rem 7rem;
  }
}
.flow .templateTitle {
  color: var(--color-white);
  margin-bottom: 6.4rem;
}
@media screen and (max-width: 768px) {
  .flow .templateTitle {
    margin-bottom: 8.4rem;
  }
}
.flow .templateTitle_span::before, .flow .templateTitle_span::after {
  background-color: var(--color-white);
}
.flow_ul {
  display: flex;
  gap: 2.8rem;
  margin-bottom: 20rem;
}
@media screen and (max-width: 768px) {
  .flow_ul {
    margin-bottom: 9.5rem;
    flex-direction: column;
  }
}
.flow_li {
  border-radius: 2.4rem;
  background-color: var(--color-white);
  padding: 1.6rem 1.6rem 3rem;
  position: relative;
  width: calc((100% - 8.4rem) / 4);
}
@media screen and (max-width: 768px) {
  .flow_li {
    width: 100%;
  }
}
.flow_li:not(:last-of-type)::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -2rem;
  transform: translate(0, -50%);
  background-image: url("../img/icon_arrow_narrow.svg");
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.2rem;
  height: 3.2rem;
}
@media screen and (max-width: 768px) {
  .flow_li:not(:last-of-type)::after {
    top: initial;
    right: initial;
    bottom: -3rem;
    left: 50%;
    transform: translate(-50%, 0) rotate(90deg);
  }
}
.flow_li_number {
  position: absolute;
  top: -2rem;
  left: -2rem;
  background-image: url("../img/about_icon_ball.webp");
  background-size: contain;
  background-repeat: no-repeat;
  width: 8rem;
  height: 7.7rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.flow_li_number_text {
  font-style: italic;
  color: var(--color-green);
  font-family: var(--font-hiragino);
  font-size: 3.2rem;
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: 0;
  position: relative;
  right: 0.2rem;
}
.flow_li_image {
  border-radius: 2.4rem;
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 768px) {
  .flow_li_image {
    aspect-ratio: 350/220;
  }
}
.flow_li_text {
  font-size: 2rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  font-weight: bold;
  color: var(--color-green);
  text-align: center;
}
@media screen and (max-width: 768px) {
  .flow_li_text {
    font-size: 2.4rem;
  }
}
.flow_using {
  max-width: 99.2rem;
  width: 100%;
  margin-inline: auto;
  display: block;
}

.attention {
  margin-bottom: 19rem;
  margin-inline: 22.4rem;
}
@media screen and (max-width: 768px) {
  .attention {
    margin-bottom: 8rem;
    margin-inline: 2rem;
  }
}
.attention .templateTitle {
  margin-bottom: 9.8rem;
}
@media screen and (max-width: 768px) {
  .attention .templateTitle {
    text-align: center;
    font-size: 6.4rem;
    line-height: 1.6;
    font-weight: 900;
    letter-spacing: 0.06em;
  }
  .attention .templateTitle_span {
    line-height: 1.8;
    font-size: 2rem;
    letter-spacing: 0.06em;
    font-weight: bold;
    text-align: center;
    display: block;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
  }
  .attention .templateTitle_span::before, .attention .templateTitle_span::after {
    content: "";
    display: inline-block;
    background-color: var(--color-gray);
    width: 6.4rem;
    height: 0.2rem;
  }
}

/* 料金ページここまで
---------- ---------- */
/* ========== ========== ==========
お問い合わせページここから
========== ========== ========== */
.form_item {
  display: flex;
  justify-content: space-between;
  gap: 1.6rem;
}
.form_items {
  margin-bottom: 6.4rem;
}
@media screen and (max-width: 768px) {
  .form_item {
    flex-direction: column;
  }
}
.form_item:not(:last-of-type) {
  margin-bottom: 5.6rem;
}
@media screen and (max-width: 768px) {
  .form_item:not(:last-of-type) {
    margin-bottom: 3.8rem;
  }
}
.form_item_label {
  margin-top: 1.2rem;
}
@media screen and (max-width: 768px) {
  .form_item_label {
    letter-spacing: 0;
  }
}
.form_item_required {
  display: inline-block;
  color: var(--color-white);
  background: linear-gradient(to bottom, #19B961 0%, #007635 100%);
  border-radius: 0.4rem;
  padding: 0.4rem 0.8rem;
  margin-right: 1rem;
}
.form_item_content {
  width: 66.4rem;
  display: flex;
  align-items: center;
  gap: 0.8rem 2.4rem;
}
@media screen and (max-width: 768px) {
  .form_item_content {
    flex-direction: column;
    width: 100%;
  }
}
.form_item_input, .form_item_textarea {
  width: 100%;
  font-size: 2rem;
  line-height: 1.8;
  letter-spacing: 0.06em;
  padding: 1.4rem 2.4rem;
  border-radius: 0.8rem;
  border: solid 0.05rem var(--color-green);
  background-color: #F2F8F5;
  color: var(--color-gray);
  opacity: 0.5;
}
@media screen and (max-width: 768px) {
  .form_item_input, .form_item_textarea {
    font-size: 2rem;
    font-weight: normal;
  }
}
.form_item_input:where(.row-2 *) {
  width: calc((100% - 2.4rem) / 2);
}
@media screen and (max-width: 768px) {
  .form_item_input:where(.row-2 *) {
    width: 100%;
  }
}
.form_item_textarea {
  height: 24rem;
}
.form_privacy {
  width: 41.6rem;
  margin-inline: auto;
  text-align: center;
  margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
  .form_privacy {
    width: 100%;
  }
}
.form_privacy_text {
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 768px) {
  .form_privacy_text {
    margin-inline: 0.7rem;
  }
}
.form_privacy_link {
  text-decoration: none;
}
.form_privacy_check {
  display: flex;
  align-items: center;
  justify-content: center;
}
.form_privacy_check_input {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 1.5rem;
  height: 1.5rem;
  margin-top: 0.5rem;
  margin-right: 1.6rem;
  border: solid 1.5px var(--color-black);
  border-radius: 4px;
  background-color: #fff;
  cursor: pointer;
  position: relative;
}
.form_privacy_check_input::before {
  content: "";
  position: absolute;
  top: 0.3rem;
  left: 0.25rem;
  right: 0;
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  background-image: url("../img/icon_check.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  display: none;
}
.form_privacy_check_input:checked::before {
  display: block;
}
.form_privacy_check_label a {
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .form .btnWrap {
    margin-inline: 2.4rem;
  }
}

/* お問い合わせページここまで
---------- ---------- */
/* ========== ========== ==========
予約ページここから
========== ========== ========== */
.supportCourse {
  margin-bottom: 12.8rem;
}
@media screen and (max-width: 768px) {
  .supportCourse .sectionWrap {
    padding-inline: 0.8rem;
  }
}
.supportCourse_inner {
  border: solid 4px var(--color-green-light);
  border-radius: 2.4rem;
  padding: 3.4rem;
  box-shadow: 4px 4px 16px rgba(0, 0, 0, 0.08);
}
.supportCourse_row {
  display: flex;
  align-items: center;
  justify-content: center;
}
.supportCourse_row:where(.-n01) {
  gap: 2.4rem 6.4rem;
}
.supportCourse_row:where(.-n02) {
  gap: 1.6rem 2.2rem;
  flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .supportCourse_row {
    flex-direction: column;
  }
}
.supportCourse_row_image:where(.-n01 *) {
  width: 32.6rem;
}
@media screen and (max-width: 768px) {
  .supportCourse_row_image:where(.-n01 *) {
    width: 21.2rem;
  }
}
.supportCourse_row_image:where(.-n02 *) {
  width: 20.7rem;
}
@media screen and (max-width: 768px) {
  .supportCourse_row_image:where(.-n02 *) {
    width: 17.2rem;
  }
}
.supportCourse_row_text1:where(.-n01 *) {
  width: 45rem;
}
.supportCourse_row_text1:where(.-n02 *) {
  width: 67rem;
  margin-bottom: 0.8rem;
}
@media screen and (max-width: 768px) {
  .supportCourse_row_text1 {
    width: 100%;
    font-size: 1.84rem;
  }
}
.supportCourse_row_text1_span1 {
  font-size: 3.2rem;
  line-height: 1.6;
  letter-spacing: 0.06em;
  font-weight: bold;
  color: var(--color-green);
  display: block;
}
@media screen and (max-width: 768px) {
  .supportCourse_row_text1_span1 {
    font-size: 2.4rem;
  }
}
.supportCourse_row_text1_span2 {
  font-size: 2.8rem;
  line-height: 1.6;
  letter-spacing: 0.06em;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .supportCourse_row_text1_span2 {
    font-size: 2.1rem;
  }
}
.supportCourse_row_text1_span3 {
  font-size: 3rem;
  font-weight: bold;
  color: var(--color-red);
}
@media screen and (max-width: 768px) {
  .supportCourse_row_text1_span3 {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .supportCourse_row_text2 {
    font-size: 1.8rem;
  }
}
.supportCourse_row_text2_span {
  color: var(--color-white);
  background-color: var(--color-green-light);
  border-radius: 999px;
  padding: 0.4rem 2.4rem;
  display: inline-block;
}
.supportCourse_row_text2_text {
  display: inline;
}
.supportCourse_arrow {
  width: 12rem;
  margin-block: 1.6rem 0.9rem;
  -o-object-fit: contain;
     object-fit: contain;
}
.supportCourse_arrowWrap {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .supportCourse_arrow {
    margin-bottom: 3.3rem;
  }
}

.textBlock {
  margin-bottom: 12.8rem;
}
.textBlock_text {
  text-align: center;
}

/* 予約ページここまで
---------- ---------- */
/* ========== ========== ==========
よくある質問ページここから
========== ========== ========== */
.faq {
  max-width: 99.2rem;
  width: 100%;
  margin-inline: auto;
}
.faq_inner {
  margin-inline: 2.4rem;
}
.faq .templateTitle2 {
  margin-bottom: 6.4rem;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .faq .templateTitle2 {
    font-size: 3.2rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    max-width: 35rem;
    margin-bottom: 4.4rem;
  }
  .faq .templateTitle2_text {
    line-height: 1.6;
  }
}
.faq_lists {
  width: 100%;
  margin-bottom: 6.4rem;
}
.faq_list {
  border-radius: 1.2rem;
  overflow: hidden;
  box-shadow: 0.4rem 0.4rem 1.6rem rgba(0, 0, 0, 0.08);
}
.faq_list:not(:last-of-type) {
  margin-bottom: 4rem;
}
.faq_list:hover {
  cursor: pointer;
}
.faq_textQ, .faq_textA {
  padding: 3.08rem;
  display: flex;
  align-items: center;
  gap: 0 1.6rem;
}
@media screen and (max-width: 768px) {
  .faq_textQ, .faq_textA {
    padding-inline: 3.24rem;
  }
}
.faq_textQ {
  background: linear-gradient(to right, #009B46 0%, #007635 100%);
  transition: all 0.3s;
}
@media screen and (min-width: 769px) {
  .faq_textQ {
    padding-right: 4.15rem;
  }
}
.faq_textQ, .faq_textQ * {
  color: var(--color-white);
}
.faq_textQ:where(.-active-faq *) {
  border-radius: 1.2rem 1.2rem 0 0;
}
@media screen and (max-width: 768px) {
  .faq_textA {
    align-items: flex-start;
  }
}
.faq_textA .faq_singleLetter {
  color: var(--color-green-light);
}
.faq_singleLetter {
  flex-shrink: 0;
}
.faq_plusMinus {
  position: relative;
  width: 1.4rem;
  height: 1.4rem;
  margin-left: auto;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .faq_plusMinus {
    width: 2.5rem;
    height: 2.5rem;
  }
}
.faq_plusMinus::before, .faq_plusMinus::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1.7rem;
  height: 0.3rem;
  border-radius: 999rem;
  background-color: var(--color-white);
}
@media screen and (max-width: 768px) {
  .faq_plusMinus::before, .faq_plusMinus::after {
    width: 1.8rem;
  }
}
.faq_plusMinus::after {
  transform: translate(-50%, -50%) rotate(270deg);
  transition: all 0.5s;
}
.faq_plusMinus:is(.-active-faq *)::after {
  transform: translate(-50%, -50%) rotate(0deg);
}
.faq_answer {
  display: none;
  background-color: var(--color-white);
}
.faq_text1 {
  margin-bottom: 6.4rem;
}
.faq_link {
  text-decoration: none;
  padding: 2.1rem 14.2rem;
  color: var(--color-green);
  border-radius: 999px;
  border: solid 0.2rem var(--color-green);
  transition: all 0.3s;
  display: inline-block;
}
.faq_linkWrap {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .faq_link {
    padding-inline: initial;
    padding-block: 2rem;
    width: 100%;
  }
}
.faq_link:hover {
  background-color: var(--color-green);
  color: var(--color-white);
}

/* よくある質問ページここまで
---------- ---------- */
/* ========== ========== ==========
プライバシーポリシーページ、利用規約ページここから
========== ========== ========== */
.privacy,
.terms {
  padding-top: 2.8rem;
  max-width: 104rem;
  margin-inline: auto;
  width: 100%;
}
.privacy_inner,
.terms_inner {
  margin-inline: 2.4rem;
}
.privacy .templateTitle3,
.terms .templateTitle3 {
  font-family: var(--font-hiragino);
  letter-spacing: 0.04em;
  font-size: 2rem;
  padding-left: 1rem;
  margin-left: 0.5rem;
  margin-bottom: 2.1rem;
}
@media screen and (max-width: 768px) {
  .privacy .templateTitle3,
.terms .templateTitle3 {
    line-height: 1.6;
    margin-left: 0;
    margin-bottom: 2.3rem;
  }
}
.privacy .templateOl_li,
.terms .templateOl_li {
  margin-bottom: 0;
  margin-left: 3.5rem;
}

.privacy .templateText {
  padding-bottom: 2.9rem;
  margin-bottom: 9.6rem;
}
.privacy .templateText:where(.-last) {
  margin-bottom: 6.4rem;
}
@media screen and (max-width: 768px) {
  .privacy .templateText {
    margin-bottom: 3.4rem;
  }
}
.privacy .templateText_text {
  line-height: 1.77;
}
@media screen and (max-width: 768px) {
  .privacy .templateText_text {
    line-height: 1.8;
    letter-spacing: 0.05em;
  }
}

.terms .templateText_text1 {
  margin-bottom: 9.6rem;
}

/* プライバシーポリシーページ、利用規約ページここまで
---------- ---------- */