@charset "UTF-8";
/* PC用 */
/* ブレイクポイント 設定 */
/* SP用 */
/* 共通 */
.br_sp {
  display: none;
}
@media only screen and (max-width: 630px) {
  .br_sp {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: block;
  }
}

.br_pc {
  display: block;
}
@media only screen and (max-width: 630px) {
  .br_pc {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: none;
  }
}

.visible_sp {
  display: none;
}
@media only screen and (max-width: 630px) {
  .visible_sp {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: block;
  }
}

.visible_pc {
  display: block;
}
@media only screen and (max-width: 630px) {
  .visible_pc {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: none;
  }
}

.wh, footer a, .fix_reservation_btn {
  color: #fff;
}
.wh:link, footer a:link, .fix_reservation_btn:link {
  color: #fff;
}
.wh:visited, footer a:visited, .fix_reservation_btn:visited {
  color: #fff;
}
.wh:hover, footer a:hover, .fix_reservation_btn:hover {
  color: #fff;
}
.wh:active, footer a:active, .fix_reservation_btn:active {
  color: #fff;
}

.right {
  text-align: right;
}

.section_ttl_L_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-weight: 200;
}
.section_ttl_L_wrap .sparking_img {
  max-width: 20px;
}
@media only screen and (max-width: 630px) {
  .section_ttl_L_wrap .sparking_img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 12px;
  }
}
.section_ttl_L_wrap .section_ttl_L2 {
  font-size: 3rem;
  margin-top: 20px;
}
@media only screen and (max-width: 630px) {
  .section_ttl_L_wrap .section_ttl_L2 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2rem;
  }
}
.section_ttl_L_wrap .span_section_ttl_L_en {
  font-size: 8rem;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  font-weight: 100;
  line-height: 0.8;
  margin-bottom: 15px;
  margin-top: 10px;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  .section_ttl_L_wrap .span_section_ttl_L_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 6rem;
  }
}
.section_ttl_L_wrap .section_ttl_L {
  font-size: 2rem;
  color: #52cbd8;
  font-weight: 500;
}
@media only screen and (max-width: 630px) {
  .section_ttl_L_wrap .section_ttl_L {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.8rem;
  }
}

.spacer {
  padding: 50px;
  margin: 50px;
}

.align-left {
  align-items: flex-start;
}

.button_wrap .button {
  display: inline-block;
  padding: 8px 60px 15px 18px;
  border-bottom: 1px solid #52cbd8;
  background-repeat: no-repeat;
  background-size: 35px;
  background-position: right 5px center;
  position: relative;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  letter-spacing: 0.05em;
  transition: background-size 0.4s ease, background-position 0.4s ease;
}
.button_wrap .button::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  width: 35px;
  height: 35px;
  background-image: url("../img/base/btn_arrow.svg");
  background-repeat: no-repeat;
  background-size: contain;
  transform: translateY(-50%) scale(1);
  transition: transform 0.4s ease;
}
.button_wrap .button:hover::before {
  transform: translateY(-50%) scale(1.6) translateX(4px);
}
.button_wrap .button::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  transform: scaleX(0);
  transform-origin: center left;
  width: 100%;
  height: 2px;
  background-color: #52cbd8;
  transition: transform 0.3s ease;
}
.button_wrap .button:hover::after {
  transform: scaleX(1);
  mix-blend-mode: soft-light;
}
.button_wrap .button:hover {
  background-size: 45px;
  background-position: right -10px center;
}

.button_wrap.blank .button:hover::before {
  transform: translateY(-50%) scale(1) translateX(4px);
}

.reservation_btn_wrap {
  display: flex;
  gap: 10px;
}
@media only screen and (max-width: 630px) {
  .reservation_btn_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    flex-direction: column;
  }
}
.reservation_btn_wrap .reservation_btn {
  display: block;
  text-align: center;
  width: 100%;
  padding: 20px 30px 20px 40px;
  color: #ffffff;
  background-repeat: no-repeat;
  background-size: 30px;
  background-position: center left 15px;
  border-radius: 5px;
  font-size: 1.7rem;
}
.reservation_btn_wrap .reservation_btn.form_btn {
  background-image: url(../img/base/ico_calendar_wh.svg);
  background-color: #e08798;
}
.reservation_btn_wrap .reservation_btn.tel_btn {
  background-image: url(../img/base/ico_tel_wh.svg);
  background-color: #4d4d4d;
}

.page_section_ttl_wrap {
  padding: 60px 20px 0px 20px;
  text-align: center;
  margin-bottom: 20px;
  margin-top: 20px;
}
@media only screen and (max-width: 630px) {
  .page_section_ttl_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px 20px 0px 20px;
  }
}

.page_section_ttl {
  font-size: 3.3rem;
  color: #4d4d4d;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  .page_section_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.5rem;
  }
}

.page_section_ttl_en {
  font-size: 2rem;
  color: #52cbd8;
  font-weight: 500;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  letter-spacing: 0.08em;
}
@media only screen and (max-width: 630px) {
  .page_section_ttl_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.6rem;
  }
}
.page_section_ttl_en.gold {
  color: #c7a640;
}

.sparking_img {
  max-width: 20px;
}

.fix_reservation_btn_wrap {
  display: flex;
  position: fixed;
  flex-direction: column;
  z-index: 99;
  right: 0;
  top: 150px;
}

.fix_reservation_btn {
  writing-mode: vertical-lr;
  color: #ffffff;
  padding: 50px 10px 20px 10px;
  font-size: 1.7rem;
  background-size: 25px;
  background-position: top 10px center;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 630px) {
  .fix_reservation_btn {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    z-index: 99;
  }
}
.fix_reservation_btn.form {
  background-color: #e08798;
  background-image: url(../img/base/ico_calendar_wh.svg);
  border-radius: 5px 0px 0px 0px;
}
.fix_reservation_btn.tel {
  background-color: #4d4d4d;
  background-image: url(../img/base/ico_tel_wh.svg);
  border-radius: 0px 0px 0px 5px;
}

.fix_reservation_btn_wrap.sp {
  display: none;
}
@media only screen and (max-width: 630px) {
  .fix_reservation_btn_wrap.sp {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: flex;
    position: fixed;
    flex-direction: row;
    z-index: 99;
    top: auto;
    right: 0;
    bottom: 0;
    width: 100%;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #ffffff;
    gap: 10px;
    padding: 10px 15px;
    font-size: 1.7rem;
    background-size: 25px;
    background-position: left 25px center;
    background-repeat: no-repeat;
    writing-mode: horizontal-tb;
    width: 100%;
    text-align: center;
    background-image: none;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn > img {
    max-width: 25px;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn:link {
    color: #fff;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn:visited {
    color: #fff;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn:hover {
    color: #fff;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn:active {
    color: #fff;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn.form {
    border-radius: 0px;
  }
  .fix_reservation_btn_wrap.sp .fix_reservation_btn.tel {
    border-radius: 0px;
  }
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  position: relative;
  font-family: YakuHanJP_Narrow, "Noto Sans JP", sans-serif;
  scroll-margin-top: 108px;
}

html {
  height: 100%;
  font-size: 62.5%;
  overflow-x: hidden !important;
}
@media only screen and (max-width: 630px) {
  html {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: clamp(6.25px, 2.5vw, 10px);
  }
}

body {
  font-size: 1.6rem;
  letter-spacing: 0.06em;
  line-height: 1.5;
}

main {
  overflow: clip;
}

.main {
  padding-top: 80px;
}
@media only screen and (max-width: 630px) {
  .main {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding-top: 70px;
  }
}

p {
  line-height: 1.8;
}

.spacer-X {
  margin-bottom: 100px;
}
@media only screen and (max-width: 630px) {
  .spacer-X {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 50px;
  }
}

.flex {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
}

.flex-02 {
  width: 50%;
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

.center {
  text-align: center;
}

h2 {
  font-size: clamp(1rem, 3vw, 1.2rem);
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  letter-spacing: 0.15rem;
}

.block {
  width: 90%;
  max-width: 600px;
  margin: 0 auto 4rem auto;
}

.half-block {
  width: 90%;
  max-width: 600px;
  margin: 0 auto 2rem auto;
}

.br_sp {
  display: none;
}

.quarter-block {
  width: 90%;
  max-width: 600px;
  margin: 0 auto 2rem auto;
}

.one-eighth-block {
  width: 90%;
  max-width: 600px;
  margin: 0 auto 0.5rem auto;
}

.pc-inner {
  max-width: 680px;
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: 10vw;
  background: #fff;
  box-shadow: 0px 0px 10px 5px rgba(72, 72, 72, 0.2);
  z-index: 10;
  transition: 0.4s;
}
@media only screen and (max-width: 630px) {
  .pc-inner {
    /*　画面サイズ $spWidth まではここを読み込む　*/
  }
}

a {
  text-decoration: none;
  color: #000000;
}
a:link {
  color: #000000;
}
a:visited {
  color: #000000;
}
a:hover {
  color: #000000;
  opacity: 0.8;
}
a:active {
  color: #000000;
}

.border-none {
  border: none !important;
}

.pd-1 {
  padding: 8px;
}

/*1200px以上*/
@media screen and (min-width: 1200px) {
  .pc-inner {
    margin-right: 5vw;
  }
}
.inner-header-wrap {
  position: fixed;
  max-width: 680px;
  width: 100%;
  z-index: 900;
  top: 0;
  box-shadow: 0px 5px 5px 0px rgba(82, 203, 216, 0.1);
}

.inner-header {
  width: 100%;
  height: 108px;
  justify-content: space-between;
  align-items: center;
  background-color: #fff;
  padding: 0 1.5rem;
}
@media only screen and (max-width: 630px) {
  .inner-header {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    height: 64px;
    padding: 0 1rem;
  }
}

.access h4 {
  margin-bottom: 0.5rem;
  font-size: clamp(1rem, 3vw, 1.25rem);
}

a:hover,
a:hover img {
  transition: 0.4s;
  opacity: 0.75;
}

.vertical {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

.caution {
  font-size: clamp(0.7rem, 2vw, 0.9rem);
}

/*基礎　500px以下*/
@media screen and (max-width: 500px) {
  .pc {
    display: none;
  }
  .br_sp {
    display: block;
  }
  .pc-bg {
    opacity: 0;
    display: none;
  }
  .flex-btn a {
    width: calc(50% - 0.25rem) !important;
  }
  .tab-01 .furisode-collection-separate {
    width: calc(33.3333333333% - 0.25rem);
    margin-bottom: 0.25rem;
  }
  .block,
  .half-block,
  .quarter-block,
  .one-eighth-block,
  .footer-main nav,
  .furisode-collection-single-fv,
  .furisode-collection-single-p,
  .furisode-collection-single-page-top,
  .info-single-fv {
    width: 92.5%;
  }
  .point-half-img {
    width: 100%;
  }
  .point-half-h {
    width: 95%;
    margin: 0 auto;
    padding: 0.5rem 0;
  }
  .point-half-h h4 {
    padding: 1rem;
  }
  .footer-flex-btn a {
    letter-spacing: normal;
  }
  .footer-flex-btn span {
    display: none;
  }
  .footer-flex-btn a:before {
    width: 0.9rem;
  }
}
header {
  width: 100%;
  z-index: 99;
  max-width: 680px;
  position: fixed;
}

.header_inner {
  display: flex;
  justify-content: space-between;
  padding: 15px 20px;
  z-index: 99;
  background-color: #ffffff;
}

.header_reservation_wrap {
  max-width: 40px;
}
@media only screen and (max-width: 630px) {
  .header_reservation_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 38px;
  }
}

.header_right_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 25px;
}

.main-logo {
  max-width: 120px;
}
@media only screen and (max-width: 630px) {
  .main-logo {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 80px;
  }
}

.header_logo {
  max-width: 100px;
  width: 10vw;
  margin-top: 5px;
}
@media only screen and (max-width: 630px) {
  .header_logo {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    min-width: 85px;
  }
}

.header_nav_wrap {
  display: block;
  position: absolute;
  top: -20px;
  right: -20px;
  transition: 0.5s ease;
  width: 33vw;
  height: 100vh;
  z-index: -1;
  opacity: 0;
  visibility: hidden; /* 非表示扱いにする */
  pointer-events: none;
}
@media only screen and (max-width: 630px) {
  .header_nav_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 100vw;
  }
}
.header_nav_wrap .header_nav_inner {
  display: flex;
  justify-content: center;
  flex-direction: column;
  height: 100vh;
  gap: 30px;
  padding: 40px;
  background: #f7f7f0;
  z-index: -1;
}
.header_nav_wrap .header_nav_item_a {
  display: block;
  padding-left: 10px;
  border-left: 3px solid #52cbd8;
  margin-bottom: 20px;
  font-size: 1.8rem;
  font-weight: 400;
}
.header_nav_wrap .header_nav_item_small_item {
  position: relative;
  padding-left: 22px;
  margin-bottom: 15px;
}
.header_nav_wrap .header_nav_item_small_item a {
  color: #4d4d4d;
  font-size: 1.6rem;
}
.header_nav_wrap .header_nav_item_small_item::before {
  content: "";
  display: block;
  position: absolute;
  width: 15px;
  height: 1px;
  background-color: #52cbd8;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.header_nav_wrap.open {
  right: -20px;
  transition: 0.5s ease;
  opacity: 1;
  z-index: 99;
  visibility: visible; /* 表示に戻す */
  pointer-events: auto;
}
.header_nav_wrap.open .header_nav_inner {
  z-index: 99;
}

.hamburger {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  width: 80px;
  position: relative;
  z-index: 999;
}
@media only screen and (max-width: 630px) {
  .hamburger {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    height: auto;
  }
}
.hamburger .hamburger_text {
  font-size: 1.6rem;
  margin-bottom: 5px;
  letter-spacing: 0.3em;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
}
@media only screen and (max-width: 630px) {
  .hamburger .hamburger_text {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 5px;
  }
}
.hamburger .hamburger_line,
.hamburger .hamburger_line2 {
  display: block;
  width: 70px;
  height: 2px;
  background-color: #333;
  margin: 3px 0;
  transition: transform 0.4s ease;
}
.hamburger.open .hamburger_line {
  transform: rotate(20deg) translateY(5px);
}
.hamburger.open .hamburger_line2 {
  transform: rotate(-20deg) translateY(-5px);
}

footer {
  background: linear-gradient(45deg, rgb(124, 200, 213) 13%, rgb(122, 228, 202) 91%);
  color: #ffffff;
}
@media only screen and (max-width: 630px) {
  footer {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 50px;
  }
}
footer a {
  color: #ffffff;
}
footer .section_access {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3vw;
}
@media only screen and (max-width: 630px) {
  footer .section_access {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    gap: 5px;
  }
}
footer .footer_logo_wrap {
  display: block;
  text-align: center;
  margin-bottom: 15px;
}
footer .footer_logo_wrap .footer_logo {
  max-width: 280px;
}
footer .add {
  letter-spacing: 0.1em;
  line-height: 1.5;
}
footer .footer_info {
  text-align: center;
  line-height: 1.5;
  margin-bottom: 40px;
}
footer .footer_copy_wrap {
  display: flex;
  justify-content: space-between;
  padding: 10px 20px;
  background: linear-gradient(45deg, rgb(124, 200, 213) 13%, rgb(122, 228, 202) 91%);
}

.footer_nav {
  margin-top: 40px;
}
.footer_nav .footer_nav_container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 30px;
  max-width: 1100px;
  margin: 0 auto;
}
.footer_nav .footer_nav_column .footer_nav_title {
  font-size: 16px;
  margin-bottom: 10px;
  font-weight: bold;
  border-bottom: 1px solid rgba(255, 255, 255, 0.6);
  padding-bottom: 5px;
  color: #fff;
  background-image: url(../img/base/btn_arrow_wh.svg);
  background-repeat: no-repeat;
  background-size: 20px;
  background-position: center right 5px;
  transition: 0.3s all ease;
}
.footer_nav .footer_nav_column .footer_nav_title a {
  display: block;
}
.footer_nav .footer_nav_column .footer_nav_title:hover {
  background-position: center right 3px;
}
.footer_nav .footer_nav_column .footer_nav_title.ico_blank {
  background-image: url(../img/base/ico_blank_wh.svg);
  background-repeat: no-repeat;
  background-size: 20px;
  background-position: center right 5px;
}
.footer_nav .footer_nav_column .footer_nav_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer_nav .footer_nav_column .footer_nav_list li {
  margin: 6px 0;
}
.footer_nav .footer_nav_column .footer_nav_list li a {
  display: block;
  font-size: 14px;
  color: #fff;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.footer_nav .footer_nav_column .footer_nav_list li a:hover {
  opacity: 0.7;
}

.white_left_ttl_en {
  color: #ffffff;
  font-size: 6.8rem;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  font-weight: 100;
  line-height: 1;
}
@media only screen and (max-width: 630px) {
  .white_left_ttl_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 3rem;
  }
}

.add {
  padding-left: 15px;
}

@media only screen and (max-width: 630px) {
  .left_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px 15px 15px 0px;
    border-right: 1px solid #ffffff;
  }
}

.white_left_ttl_ja {
  font-size: 2.8rem;
  color: #ffffff;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  .white_left_ttl_ja {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
  }
}

.bg_movie {
  position: fixed;
  right: 0;
  bottom: 0;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: -1; /* 背景に回す */
  object-fit: cover; /* アスペクト比を保って全画面にフィット */
  mix-blend-mode: plus-lighter;
  opacity: 0.1;
}

.pc-bg {
  background: url(../img/base/pc-bg.jpg);
  background-position: top left;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  position: fixed;
  height: 100%;
}

/*1000px以下*/
@media screen and (max-width: 1000px) {
  .pc-bg {
    opacity: 0.5;
    transition: 0.4s;
  }
}
.scroll-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
}

@keyframes pc-bg-scroll-right {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0%);
  }
}
.scroll-right-wrap {
  animation: pc-bg-scroll-right 70s infinite linear 0.5s both;
  justify-content: space-around;
  flex-wrap: nowrap;
  height: 0;
  top: 20vh;
  transform: translateX(-50%); /* 最初に左に半分ずらしておく！ */
}

.scroll-right-wrap ul {
  flex-wrap: nowrap;
}

.scroll-right-wrap ul li {
  list-style: none;
  min-width: 350px;
  margin-right: 10rem;
}

@keyframes pc-bg-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
.scroll-left-wrap {
  display: flex;
  animation: pc-bg-scroll-left 70s infinite linear 0.5s both;
}

.pc-bg-p {
  font-size: 19rem;
  font-family: "NewYork", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  letter-spacing: 0.15rem;
  font-weight: 300;
  white-space: nowrap;
  padding: 0;
  top: 30vh;
  letter-spacing: 1rem;
  color: #fff;
  opacity: 0.7;
}

.pc-bg-menu {
  width: calc(100% - 60px);
  height: 100%;
  margin: 4rem auto;
  max-width: 1200px;
}

.pc-bg-menu ul li {
  list-style: none;
}

.pc-bg-menu ul li a {
  text-decoration: none;
}

.pc-bg-top {
  align-items: center;
}

.pc-bg-top-right {
  margin-left: 3rem;
  font-weight: bold;
  transition: 0.4s;
}

.pc-bg-top-right li {
  margin-left: 1.5rem;
}

/*1200px以下*/
@media screen and (max-width: 1200px) {
  .pc-bg-top-right {
    visibility: hidden;
    opacity: 0;
  }
  .pc-bg-bottom ul {
    visibility: hidden;
  }
}
/*1600px以下*/
@media screen and (max-width: 1600px) {
  .pc-bg-top-right li {
    margin-left: 0.5rem;
  }
}
.pc-bg-top-right li a {
  font-size: clamp(0.8rem, 2vw, 1rem);
  color: #333333;
  letter-spacing: 0.15rem;
}

.pc-bg-top-right img {
  width: 3rem;
  top: -0.15rem;
  margin-left: 1rem;
}

.pc-bg-bottom {
  bottom: 7.5rem;
  position: absolute;
}

.pc-bg-bottom .c {
  margin-left: 4rem;
  font-weight: bold;
  letter-spacing: 0.15rem;
  text-decoration: none;
  color: #4d4d4d;
  transition: 0.4s;
}

.pc-bg-bottom ul {
  transition: 0.4s;
}

/*1200px以下*/
@media screen and (max-width: 1200px) {
  .pc-bg-bottom ul {
    visibility: hidden;
    opacity: 0;
  }
  .pc-bg-bottom .c {
    position: absolute;
  }
}
.full-wrap {
  width: 100%;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  margin-bottom: 1rem;
}

.privacy_p {
  font-size: 1.6rem;
  color: #4d4d4d !important;
}

.pc-inner {
  overflow: hidden !important;
}

.dots-wrap {
  display: flex;
  justify-content: center;
}

@media only screen and (max-width: 630px) {
  .dots-wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-top: 0px;
  }
}

.dots-wrap li {
  width: 10px;
  height: 10px;
  margin: 0 5px;
  border: 1px solid #52cbd8;
  border-radius: 50%;
  cursor: pointer;
}

.dots-wrap li:hover,
.dots-wrap li.slick-active {
  background: #52cbd8;
}

.dots-wrap li button {
  display: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  padding: 0;
  border: none;
  background-color: transparent;
}

@media print {
  body {
    zoom: 50%;
    width: 100% !important;
  }
  #pagetop {
    display: none !important;
  }
}
/* 共通 */
.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  box-sizing: border-box;
}

.shrink-vspace {
  padding-top: 0;
  padding-bottom: 0;
}

.container-fluid {
  width: 100%;
  max-width: auto;
  margin-right: auto;
  margin-left: auto;
  box-sizing: border-box;
}

.inner-width {
  max-width: 980px;
}

main {
  overflow-x: hidden;
}

/* PC */
.container {
  max-width: 1260px;
}

.container,
.container-fluid {
  padding-left: 30px;
  padding-right: 30px;
  padding-top: 60px;
  padding-bottom: 60px;
}

.row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: calc(30px / 2 - 30px);
  margin-left: calc(30px / 2 - 30px);
  /* margin-top: v.$vSpace / 2;*/
}

.row + .row {
  margin-top: 60px;
}

.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-10,
.col-11,
.col-12 {
  position: relative;
  box-sizing: border-box;
  padding: 30px/2;
}

.col-1 {
  -ms-flex: 0 0 8.333333%;
  flex: 0 0 8.333333%;
  max-width: 8.333333%;
}

.col-2 {
  -ms-flex: 0 0 16.666667%;
  flex: 0 0 16.666667%;
  max-width: 16.666667%;
}

.col-3 {
  -ms-flex: 0 0 25%;
  flex: 0 0 25%;
  max-width: 25%;
}

.col-4 {
  -ms-flex: 0 0 33.333333%;
  flex: 0 0 33.333333%;
  max-width: 33.333333%;
}

.col-5 {
  -ms-flex: 0 0 41.666667%;
  flex: 0 0 41.666667%;
  max-width: 41.666667%;
}

.col-6 {
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
}

.col-7 {
  -ms-flex: 0 0 58.333333%;
  flex: 0 0 58.333333%;
  max-width: 58.333333%;
}

.col-8 {
  -ms-flex: 0 0 66.666667%;
  flex: 0 0 66.666667%;
  max-width: 66.666667%;
}

.col-9 {
  -ms-flex: 0 0 75%;
  flex: 0 0 75%;
  max-width: 75%;
}

.col-10 {
  -ms-flex: 0 0 83.333333%;
  flex: 0 0 83.333333%;
  max-width: 83.333333%;
}

.col-11 {
  -ms-flex: 0 0 91.666667%;
  flex: 0 0 91.666667%;
  max-width: 91.666667%;
}

.col-12 {
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
  max-width: 100%;
}

.order-first {
  -ms-flex-order: -1;
  order: -1;
}

.order-last {
  -ms-flex-order: 13;
  order: 13;
}

.order-0 {
  -ms-flex-order: 0;
  order: 0;
}

.order-1 {
  -ms-flex-order: 1;
  order: 1;
}

.order-2 {
  -ms-flex-order: 2;
  order: 2;
}

.order-3 {
  -ms-flex-order: 3;
  order: 3;
}

.order-4 {
  -ms-flex-order: 4;
  order: 4;
}

.order-5 {
  -ms-flex-order: 5;
  order: 5;
}

.order-6 {
  -ms-flex-order: 6;
  order: 6;
}

.order-7 {
  -ms-flex-order: 7;
  order: 7;
}

.order-8 {
  -ms-flex-order: 8;
  order: 8;
}

.order-9 {
  -ms-flex-order: 9;
  order: 9;
}

.order-10 {
  -ms-flex-order: 10;
  order: 10;
}

.order-11 {
  -ms-flex-order: 11;
  order: 11;
}

.order-12 {
  -ms-flex-order: 12;
  order: 12;
}

.m-0 {
  margin: 0 !important;
}

.mt-0,
.my-0 {
  margin-top: 0 !important;
}

.mr-0,
.mx-0 {
  margin-right: 0 !important;
}

.mb-0,
.my-0 {
  margin-bottom: 0 !important;
}

.ml-0,
.mx-0 {
  margin-left: 0 !important;
}

.m-1 {
  margin: 2rem !important;
}

.mt-1,
.my-1 {
  margin-top: 1rem !important;
}

.mr-1,
.mx-1 {
  margin-right: 1rem !important;
}

.mb-1,
.my-1 {
  margin-bottom: 1rem !important;
}

.ml-1,
.mx-1 {
  margin-left: 1rem !important;
}

.m-2 {
  margin: 2rem !important;
}

.mt-2,
.my-2 {
  margin-top: 2rem !important;
}

.mr-2,
.mx-2 {
  margin-right: 2rem !important;
}

.mb-2,
.my-2 {
  margin-bottom: 2rem !important;
}

.ml-2,
.mx-2 {
  margin-left: 2rem !important;
}

.m-3 {
  margin: 3rem !important;
}

.mt-3,
.my-3 {
  margin-top: 3rem !important;
}

.mr-3,
.mx-3 {
  margin-right: 3rem !important;
}

.mb-3,
.my-3 {
  margin-bottom: 3rem !important;
}

.ml-3,
.mx-3 {
  margin-left: 3rem !important;
}

.m-4 {
  margin: 4rem !important;
}

.mt-4,
.my-4 {
  margin-top: 4rem !important;
}

.mr-4,
.mx-4 {
  margin-right: 4rem !important;
}

.mb-4,
.my-4 {
  margin-bottom: 4rem !important;
}

.ml-4,
.mx-4 {
  margin-left: 4rem !important;
}

.m-5 {
  margin: 5rem !important;
}

.mt-5,
.my-5 {
  margin-top: 5rem !important;
}

.mr-5,
.mx-5 {
  margin-right: 5rem !important;
}

.mb-5,
.my-5 {
  margin-bottom: 5rem !important;
}

.ml-5,
.mx-5 {
  margin-left: 5rem !important;
}

.p-0 {
  padding: 0 !important;
}

.pt-0,
.py-0 {
  padding-top: 0 !important;
}

.pr-0,
.px-0 {
  padding-right: 0 !important;
}

.pb-0,
.py-0 {
  padding-bottom: 0 !important;
}

.pl-0,
.px-0 {
  padding-left: 0 !important;
}

.p-1 {
  padding: 1rem !important;
}

.pt-1,
.py-1 {
  padding-top: 1rem !important;
}

.pr-1,
.px-1 {
  padding-right: 1rem !important;
}

.pb-1,
.py-1 {
  padding-bottom: 1rem !important;
}

.pl-1,
.px-1 {
  padding-left: 1rem !important;
}

.p-2 {
  padding: 2rem !important;
}

.pt-2,
.py-2 {
  padding-top: 2rem !important;
}

.pr-2,
.px-2 {
  padding-right: 2rem !important;
}

.pb-2,
.py-2 {
  padding-bottom: 2rem !important;
}

.pl-2,
.px-2 {
  padding-left: 2rem !important;
}

.p-3 {
  padding: 3rem !important;
}

.pt-3,
.py-3 {
  padding-top: 3rem !important;
}

.pr-3,
.px-3 {
  padding-right: 3rem !important;
}

.pb-3,
.py-3 {
  padding-bottom: 3rem !important;
}

.pl-3,
.px-3 {
  padding-left: 3rem !important;
}

.p-4 {
  padding: 4rem !important;
}

.pt-4,
.py-4 {
  padding-top: 4rem !important;
}

.pr-4,
.px-4 {
  padding-right: 4rem !important;
}

.pb-4,
.py-4 {
  padding-bottom: 4rem !important;
}

.pl-4,
.px-4 {
  padding-left: 4rem !important;
}

.p-5 {
  padding: 5rem !important;
}

.pt-5,
.py-5 {
  padding-top: 5rem !important;
}

.pt-6 {
  padding-top: 6rem !important;
}

.pt-7 {
  padding-top: 7rem !important;
}

.pt-8 {
  padding-top: 8rem !important;
}

.pt-9 {
  padding-top: 9rem !important;
}

.pr-5,
.px-5 {
  padding-right: 5rem !important;
}

.pb-5,
.py-5 {
  padding-bottom: 5rem !important;
}

.pl-5,
.px-5 {
  padding-left: 5rem !important;
}

.m-n1 {
  margin: -1rem !important;
}

.mt-n1,
.my-n1 {
  margin-top: -1rem !important;
}

.mr-n1,
.mx-n1 {
  margin-right: -1rem !important;
}

.mb-n1,
.my-n1 {
  margin-bottom: -1rem !important;
}

.ml-n1,
.mx-n1 {
  margin-left: -1rem !important;
}

.m-n2 {
  margin: -2rem !important;
}

.mt-n2,
.my-n2 {
  margin-top: -2rem !important;
}

.mr-n2,
.mx-n2 {
  margin-right: -2rem !important;
}

.mb-n2,
.my-n2 {
  margin-bottom: -2rem !important;
}

.ml-n2,
.mx-n2 {
  margin-left: -2rem !important;
}

.m-n3 {
  margin: -3rem !important;
}

.mt-n3,
.my-n3 {
  margin-top: -3rem !important;
}

.mr-n3,
.mx-n3 {
  margin-right: -3rem !important;
}

.mb-n3,
.my-n3 {
  margin-bottom: -3rem !important;
}

.ml-n3,
.mx-n3 {
  margin-left: -3rem !important;
}

.m-n4 {
  margin: -4rem !important;
}

.mt-n4,
.my-n4 {
  margin-top: -4rem !important;
}

.mr-n4,
.mx-n4 {
  margin-right: -4rem !important;
}

.mb-n4,
.my-n4 {
  margin-bottom: -4rem !important;
}

.ml-n4,
.mx-n4 {
  margin-left: -4rem !important;
}

.m-n5 {
  margin: -5rem !important;
}

.mt-n5,
.my-n5 {
  margin-top: -5rem !important;
}

.mr-n5,
.mx-n5 {
  margin-right: -5rem !important;
}

.mb-n5,
.my-n5 {
  margin-bottom: -5rem !important;
}

.ml-n5,
.mx-n5 {
  margin-left: -5rem !important;
}

.m-auto {
  margin: auto !important;
}

.mt-auto,
.my-auto {
  margin-top: auto !important;
}

.mr-auto,
.mx-auto {
  margin-right: auto !important;
}

.mb-auto,
.my-auto {
  margin-bottom: auto !important;
}

.ml-auto,
.mx-auto {
  margin-left: auto !important;
}

.offset-1 {
  margin-left: 8.3333333333%;
}

.offset-2 {
  margin-left: 16.6666666667%;
}

.offset-3 {
  margin-left: 25%;
}

.offset-4 {
  margin-left: 33.3333333333%;
}

.offset-5 {
  margin-left: 41.6666666667%;
}

.offset-6 {
  margin-left: 50%;
}

.offset-7 {
  margin-left: 58.3333333333%;
}

.offset-8 {
  margin-left: 66.6666666667%;
}

.offset-9 {
  margin-left: 75%;
}

.offset-10 {
  margin-left: 83.3333333333%;
}

.offset-11 {
  margin-left: 91.6666666667%;
}

/* タブレット グリッドシステム */
@media only screen and (max-width: 1024px) {
  .col-md-1 {
    -ms-flex: 0 0 8.333333%;
    flex: 0 0 8.333333%;
    max-width: 8.333333%;
  }
  .col-md-2 {
    -ms-flex: 0 0 16.666667%;
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
  }
  .col-md-3 {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-md-4 {
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }
  .col-md-5 {
    -ms-flex: 0 0 41.666667%;
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
  }
  .col-md-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-md-7 {
    -ms-flex: 0 0 58.333333%;
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
  }
  .col-md-8 {
    -ms-flex: 0 0 66.666667%;
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
  }
  .col-md-9 {
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-md-10 {
    -ms-flex: 0 0 83.333333%;
    flex: 0 0 83.333333%;
    max-width: 83.333333%;
  }
  .col-md-11 {
    -ms-flex: 0 0 91.666667%;
    flex: 0 0 91.666667%;
    max-width: 91.666667%;
  }
  .col-md-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-md-first {
    -ms-flex-order: -1;
    order: -1;
  }
  .order-md-last {
    -ms-flex-order: 13;
    order: 13;
  }
  .order-md-0 {
    -ms-flex-order: 0;
    order: 0;
  }
  .order-md-1 {
    -ms-flex-order: 1;
    order: 1;
  }
  .order-md-2 {
    -ms-flex-order: 2;
    order: 2;
  }
  .order-md-3 {
    -ms-flex-order: 3;
    order: 3;
  }
  .order-md-4 {
    -ms-flex-order: 4;
    order: 4;
  }
  .order-md-5 {
    -ms-flex-order: 5;
    order: 5;
  }
  .order-md-6 {
    -ms-flex-order: 6;
    order: 6;
  }
  .order-md-7 {
    -ms-flex-order: 7;
    order: 7;
  }
  .order-md-8 {
    -ms-flex-order: 8;
    order: 8;
  }
  .order-md-9 {
    -ms-flex-order: 9;
    order: 9;
  }
  .order-md-10 {
    -ms-flex-order: 10;
    order: 10;
  }
  .order-md-11 {
    -ms-flex-order: 11;
    order: 11;
  }
  .order-md-12 {
    -ms-flex-order: 12;
    order: 12;
  }
  .m-md-0 {
    margin: 0 !important;
  }
  .mt-md-0,
  .my-md-0 {
    margin-top: 0 !important;
  }
  .mr-md-0,
  .mx-md-0 {
    margin-right: 0 !important;
  }
  .mb-md-0,
  .my-md-0 {
    margin-bottom: 0 !important;
  }
  .ml-md-0,
  .mx-md-0 {
    margin-left: 0 !important;
  }
  .m-md-1 {
    margin: 1rem !important;
  }
  .mt-md-1,
  .my-md-1 {
    margin-top: 1rem !important;
  }
  .mr-md-1,
  .mx-md-1 {
    margin-right: 1rem !important;
  }
  .mb-md-1,
  .my-md-1 {
    margin-bottom: 1rem !important;
  }
  .ml-md-1,
  .mx-md-1 {
    margin-left: 1rem !important;
  }
  .m-md-2 {
    margin: 2rem !important;
  }
  .mt-md-2,
  .my-md-2 {
    margin-top: 2rem !important;
  }
  .mr-md-2,
  .mx-md-2 {
    margin-right: 2rem !important;
  }
  .mb-md-2,
  .my-md-2 {
    margin-bottom: 2rem !important;
  }
  .ml-md-2,
  .mx-md-2 {
    margin-left: 2rem !important;
  }
  .m-md-3 {
    margin: 3rem !important;
  }
  .mt-md-3,
  .my-md-3 {
    margin-top: 3rem !important;
  }
  .mr-md-3,
  .mx-md-3 {
    margin-right: 3rem !important;
  }
  .mb-md-3,
  .my-md-3 {
    margin-bottom: 3rem !important;
  }
  .ml-md-3,
  .mx-md-3 {
    margin-left: 3rem !important;
  }
  .m-md-4 {
    margin: 4rem !important;
  }
  .mt-md-4,
  .my-md-4 {
    margin-top: 4rem !important;
  }
  .mr-md-4,
  .mx-md-4 {
    margin-right: 4rem !important;
  }
  .mb-md-4,
  .my-md-4 {
    margin-bottom: 4rem !important;
  }
  .ml-md-4,
  .mx-md-4 {
    margin-left: 4rem !important;
  }
  .m-md-5 {
    margin: 5rem !important;
  }
  .mt-md-5,
  .my-md-5 {
    margin-top: 5rem !important;
  }
  .mr-md-5,
  .mx-md-5 {
    margin-right: 5rem !important;
  }
  .mb-md-5,
  .my-md-5 {
    margin-bottom: 5rem !important;
  }
  .ml-md-5,
  .mx-md-5 {
    margin-left: 5rem !important;
  }
  .p-md-0 {
    padding: 0 !important;
  }
  .pt-md-0,
  .py-md-0 {
    padding-top: 0 !important;
  }
  .pr-md-0,
  .px-md-0 {
    padding-right: 0 !important;
  }
  .pb-md-0,
  .py-md-0 {
    padding-bottom: 0 !important;
  }
  .pl-md-0,
  .px-md-0 {
    padding-left: 0 !important;
  }
  .p-md-1 {
    padding: 1rem !important;
  }
  .pt-md-1,
  .py-md-1 {
    padding-top: 1rem !important;
  }
  .pr-md-1,
  .px-md-1 {
    padding-right: 1rem !important;
  }
  .pb-md-1,
  .py-md-1 {
    padding-bottom: 1rem !important;
  }
  .pl-md-1,
  .px-md-1 {
    padding-left: 1rem !important;
  }
  .p-md-2 {
    padding: 2rem !important;
  }
  .pt-md-2,
  .py-md-2 {
    padding-top: 2rem !important;
  }
  .pr-md-2,
  .px-md-2 {
    padding-right: 2rem !important;
  }
  .pb-md-2,
  .py-md-2 {
    padding-bottom: 2rem !important;
  }
  .pl-md-2,
  .px-md-2 {
    padding-left: 2rem !important;
  }
  .p-md-3 {
    padding: 3rem !important;
  }
  .pt-md-3,
  .py-md-3 {
    padding-top: 3rem !important;
  }
  .pr-md-3,
  .px-md-3 {
    padding-right: 3rem !important;
  }
  .pb-md-3,
  .py-md-3 {
    padding-bottom: 3rem !important;
  }
  .pl-md-3,
  .px-md-3 {
    padding-left: 3rem !important;
  }
  .p-md-4 {
    padding: 4rem !important;
  }
  .pt-md-4,
  .py-md-4 {
    padding-top: 4rem !important;
  }
  .pr-md-4,
  .px-md-4 {
    padding-right: 4rem !important;
  }
  .pb-md-4,
  .py-md-4 {
    padding-bottom: 4rem !important;
  }
  .pl-md-4,
  .px-md-4 {
    padding-left: 4rem !important;
  }
  .p-md-5 {
    padding: 5rem !important;
  }
  .pt-md-5,
  .py-md-5 {
    padding-top: 5rem !important;
  }
  .pr-md-5,
  .px-md-5 {
    padding-right: 5rem !important;
  }
  .pb-md-5,
  .py-md-5 {
    padding-bottom: 5rem !important;
  }
  .pl-md-5,
  .px-md-5 {
    padding-left: 5rem !important;
  }
  .m-md-n1 {
    margin: -1rem !important;
  }
  .mt-md-n1,
  .my-md-n1 {
    margin-top: -1rem !important;
  }
  .mr-md-n1,
  .mx-md-n1 {
    margin-right: -1rem !important;
  }
  .mb-md-n1,
  .my-md-n1 {
    margin-bottom: -1rem !important;
  }
  .ml-md-n1,
  .mx-md-n1 {
    margin-left: -1rem !important;
  }
  .m-md-n2 {
    margin: -2rem !important;
  }
  .mt-md-n2,
  .my-md-n2 {
    margin-top: -2rem !important;
  }
  .mr-md-n2,
  .mx-md-n2 {
    margin-right: -2rem !important;
  }
  .mb-md-n2,
  .my-md-n2 {
    margin-bottom: -2rem !important;
  }
  .ml-md-n2,
  .mx-md-n2 {
    margin-left: -2rem !important;
  }
  .m-md-n3 {
    margin: -3rem !important;
  }
  .mt-md-n3,
  .my-md-n3 {
    margin-top: -3rem !important;
  }
  .mr-md-n3,
  .mx-md-n3 {
    margin-right: -3rem !important;
  }
  .mb-md-n3,
  .my-md-n3 {
    margin-bottom: -3rem !important;
  }
  .ml-md-n3,
  .mx-md-n3 {
    margin-left: -3rem !important;
  }
  .m-md-n4 {
    margin: -4rem !important;
  }
  .mt-md-n4,
  .my-md-n4 {
    margin-top: -4rem !important;
  }
  .mr-md-n4,
  .mx-md-n4 {
    margin-right: -4rem !important;
  }
  .mb-md-n4,
  .my-md-n4 {
    margin-bottom: -4rem !important;
  }
  .ml-md-n4,
  .mx-md-n4 {
    margin-left: -4rem !important;
  }
  .m-md-n5 {
    margin: -5rem !important;
  }
  .mt-md-n5,
  .my-md-n5 {
    margin-top: -5rem !important;
  }
  .mr-md-n5,
  .mx-md-n5 {
    margin-right: -5rem !important;
  }
  .mb-md-n5,
  .my-md-n5 {
    margin-bottom: -5rem !important;
  }
  .ml-md-n5,
  .mx-md-n5 {
    margin-left: -5rem !important;
  }
  .m-md-auto {
    margin: auto !important;
  }
  .mt-md-auto,
  .my-md-auto {
    margin-top: auto !important;
  }
  .mr-md-auto,
  .mx-md-auto {
    margin-right: auto !important;
  }
  .mb-md-auto,
  .my-md-auto {
    margin-bottom: auto !important;
  }
  .ml-md-auto,
  .mx-md-auto {
    margin-left: auto !important;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.3333333333%;
  }
  .offset-md-2 {
    margin-left: 16.6666666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.3333333333%;
  }
  .offset-md-5 {
    margin-left: 41.6666666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.3333333333%;
  }
  .offset-md-8 {
    margin-left: 66.6666666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.3333333333%;
  }
  .offset-md-11 {
    margin-left: 91.6666666667%;
  }
}
@media only screen and (max-width: 630px) {
  .container,
  .container-fluid {
    padding-left: clamp(0px, 5vw, 30px);
    padding-right: clamp(0px, 5vw, 30px);
    padding-top: clamp(10px, 7.5vw, 30px);
    padding-bottom: clamp(10px, 7.5vw, 60px);
  }
  .row {
    margin-right: calc(5vw / 2 - 5vw);
    margin-left: calc(5vw / 2 - 5vw);
    /* margin-top: clamp(0px, v.$spVSpace, v.$vSpace / 2);*/
  }
  .row + .row {
    margin-top: clamp(0px, 7.5vw, 60px);
  }
  .col-sp-1,
  .col-sp-2,
  .col-sp-3,
  .col-sp-4,
  .col-sp-5,
  .col-sp-6,
  .col-sp-7,
  .col-sp-8,
  .col-sp-9,
  .col-sp-10,
  .col-sp-11,
  .col-sp-12 {
    padding: clamp(10px, 2.5vw, 2.5vw);
  }
  .col-sp-1 {
    -ms-flex: 0 0 8.333333%;
    flex: 0 0 8.333333%;
    max-width: 8.333333%;
  }
  .col-sp-2 {
    -ms-flex: 0 0 16.666667%;
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
  }
  .col-sp-3 {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-sp-4 {
    -ms-flex: 0 0 33.333333%;
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }
  .col-sp-5 {
    -ms-flex: 0 0 41.666667%;
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
  }
  .col-sp-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-sp-7 {
    -ms-flex: 0 0 58.333333%;
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
  }
  .col-sp-8 {
    -ms-flex: 0 0 66.666667%;
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
  }
  .col-sp-9 {
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-sp-10 {
    -ms-flex: 0 0 83.333333%;
    flex: 0 0 83.333333%;
    max-width: 83.333333%;
  }
  .col-sp-11 {
    -ms-flex: 0 0 91.666667%;
    flex: 0 0 91.666667%;
    max-width: 91.666667%;
  }
  .col-sp-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
  }
  .order-sp-first {
    -ms-flex-order: -1;
    order: -1;
  }
  .order-sp-last {
    -ms-flex-order: 13;
    order: 13;
  }
  .order-sp-0 {
    -ms-flex-order: 0;
    order: 0;
  }
  .order-sp-1 {
    -ms-flex-order: 1;
    order: 1;
  }
  .order-sp-2 {
    -ms-flex-order: 2;
    order: 2;
  }
  .order-sp-3 {
    -ms-flex-order: 3;
    order: 3;
  }
  .order-sp-4 {
    -ms-flex-order: 4;
    order: 4;
  }
  .order-sp-5 {
    -ms-flex-order: 5;
    order: 5;
  }
  .order-sp-6 {
    -ms-flex-order: 6;
    order: 6;
  }
  .order-sp-7 {
    -ms-flex-order: 7;
    order: 7;
  }
  .order-sp-8 {
    -ms-flex-order: 8;
    order: 8;
  }
  .order-sp-9 {
    -ms-flex-order: 9;
    order: 9;
  }
  .order-sp-10 {
    -ms-flex-order: 10;
    order: 10;
  }
  .order-sp-11 {
    -ms-flex-order: 11;
    order: 11;
  }
  .order-sp-12 {
    -ms-flex-order: 12;
    order: 12;
  }
  .m-sp-0 {
    margin: 0 !important;
  }
  .mt-sp-0,
  .my-sp-0 {
    margin-top: 0 !important;
  }
  .mr-sp-0,
  .mx-sp-0 {
    margin-right: 0 !important;
  }
  .mb-sp-0,
  .my-sp-0 {
    margin-bottom: 0 !important;
  }
  .ml-sp-0,
  .mx-sp-0 {
    margin-left: 0 !important;
  }
  .m-sp-1 {
    margin: 1rem !important;
  }
  .mt-sp-1,
  .my-sp-1 {
    margin-top: 1rem !important;
  }
  .mr-sp-1,
  .mx-sp-1 {
    margin-right: 1rem !important;
  }
  .mb-sp-1,
  .my-sp-1 {
    margin-bottom: 1rem !important;
  }
  .ml-sp-1,
  .mx-sp-1 {
    margin-left: 1rem !important;
  }
  .m-sp-2 {
    margin: 2rem !important;
  }
  .mt-sp-2,
  .my-sp-2 {
    margin-top: 2rem !important;
  }
  .mr-sp-2,
  .mx-sp-2 {
    margin-right: 2rem !important;
  }
  .mb-sp-2,
  .my-sp-2 {
    margin-bottom: 2rem !important;
  }
  .ml-sp-2,
  .mx-sp-2 {
    margin-left: 2rem !important;
  }
  .m-sp-3 {
    margin: 3rem !important;
  }
  .mt-sp-3,
  .my-sp-3 {
    margin-top: 3rem !important;
  }
  .mr-sp-3,
  .mx-sp-3 {
    margin-right: 3rem !important;
  }
  .mb-sp-3,
  .my-sp-3 {
    margin-bottom: 3rem !important;
  }
  .ml-sp-3,
  .mx-sp-3 {
    margin-left: 3rem !important;
  }
  .m-sp-4 {
    margin: 4rem !important;
  }
  .mt-sp-4,
  .my-sp-4 {
    margin-top: 4rem !important;
  }
  .mr-sp-4,
  .mx-sp-4 {
    margin-right: 4rem !important;
  }
  .mb-sp-4,
  .my-sp-4 {
    margin-bottom: 4rem !important;
  }
  .ml-sp-4,
  .mx-sp-4 {
    margin-left: 4rem !important;
  }
  .m-sp-5 {
    margin: 5rem !important;
  }
  .mt-sp-5,
  .my-sp-5 {
    margin-top: 5rem !important;
  }
  .mr-sp-5,
  .mx-sp-5 {
    margin-right: 5rem !important;
  }
  .mb-sp-5,
  .my-sp-5 {
    margin-bottom: 5rem !important;
  }
  .ml-sp-5,
  .mx-sp-5 {
    margin-left: 5rem !important;
  }
  .p-sp-0 {
    padding: 0 !important;
  }
  .pt-sp-0,
  .py-sp-0 {
    padding-top: 0 !important;
  }
  .pr-sp-0,
  .px-sp-0 {
    padding-right: 0 !important;
  }
  .pb-sp-0,
  .py-sp-0 {
    padding-bottom: 0 !important;
  }
  .pl-sp-0,
  .px-sp-0 {
    padding-left: 0 !important;
  }
  .p-sp-1 {
    padding: 1rem !important;
  }
  .pt-sp-1,
  .py-sp-1 {
    padding-top: 1rem !important;
  }
  .pr-sp-1,
  .px-sp-1 {
    padding-right: 1rem !important;
  }
  .pb-sp-1,
  .py-sp-1 {
    padding-bottom: 1rem !important;
  }
  .pl-sp-1,
  .px-sp-1 {
    padding-left: 1rem !important;
  }
  .p-sp-2 {
    padding: 2rem !important;
  }
  .pt-sp-2,
  .py-sp-2 {
    padding-top: 2rem !important;
  }
  .pr-sp-2,
  .px-sp-2 {
    padding-right: 2rem !important;
  }
  .pb-sp-2,
  .py-sp-2 {
    padding-bottom: 2rem !important;
  }
  .pl-sp-2,
  .px-sp-2 {
    padding-left: 2rem !important;
  }
  .p-sp-3 {
    padding: 3rem !important;
  }
  .pt-sp-3,
  .py-sp-3 {
    padding-top: 3rem !important;
  }
  .pr-sp-3,
  .px-sp-3 {
    padding-right: 3rem !important;
  }
  .pb-sp-3,
  .py-sp-3 {
    padding-bottom: 3rem !important;
  }
  .pl-sp-3,
  .px-sp-3 {
    padding-left: 3rem !important;
  }
  .p-sp-4 {
    padding: 4rem !important;
  }
  .pt-sp-4,
  .py-sp-4 {
    padding-top: 4rem !important;
  }
  .pr-sp-4,
  .px-sp-4 {
    padding-right: 4rem !important;
  }
  .pb-sp-4,
  .py-sp-4 {
    padding-bottom: 4rem !important;
  }
  .pl-sp-4,
  .px-sp-4 {
    padding-left: 4rem !important;
  }
  .p-sp-5 {
    padding: 5rem !important;
  }
  .pt-sp-5,
  .py-sp-5 {
    padding-top: 5rem !important;
  }
  .pr-sp-5,
  .px-sp-5 {
    padding-right: 5rem !important;
  }
  .pb-sp-5,
  .py-sp-5 {
    padding-bottom: 5rem !important;
  }
  .pl-sp-5,
  .px-sp-5 {
    padding-left: 5rem !important;
  }
  .m-sp-n1 {
    margin: -1rem !important;
  }
  .mt-sp-n1,
  .my-sp-n1 {
    margin-top: -1rem !important;
  }
  .mr-sp-n1,
  .mx-sp-n1 {
    margin-right: -1rem !important;
  }
  .mb-sp-n1,
  .my-sp-n1 {
    margin-bottom: -1rem !important;
  }
  .ml-sp-n1,
  .mx-sp-n1 {
    margin-left: -1rem !important;
  }
  .m-sp-n2 {
    margin: -2rem !important;
  }
  .mt-sp-n2,
  .my-sp-n2 {
    margin-top: -2rem !important;
  }
  .mr-sp-n2,
  .mx-sp-n2 {
    margin-right: -2rem !important;
  }
  .mb-sp-n2,
  .my-sp-n2 {
    margin-bottom: -2rem !important;
  }
  .ml-sp-n2,
  .mx-sp-n2 {
    margin-left: -2rem !important;
  }
  .m-sp-n3 {
    margin: -3rem !important;
  }
  .mt-sp-n3,
  .my-sp-n3 {
    margin-top: -3rem !important;
  }
  .mr-sp-n3,
  .mx-sp-n3 {
    margin-right: -3rem !important;
  }
  .mb-sp-n3,
  .my-sp-n3 {
    margin-bottom: -3rem !important;
  }
  .ml-sp-n3,
  .mx-sp-n3 {
    margin-left: -3rem !important;
  }
  .m-sp-n4 {
    margin: -4rem !important;
  }
  .mt-sp-n4,
  .my-sp-n4 {
    margin-top: -4rem !important;
  }
  .mr-sp-n4,
  .mx-sp-n4 {
    margin-right: -4rem !important;
  }
  .mb-sp-n4,
  .my-sp-n4 {
    margin-bottom: -4rem !important;
  }
  .ml-sp-n4,
  .mx-sp-n4 {
    margin-left: -4rem !important;
  }
  .m-sp-n5 {
    margin: -5rem !important;
  }
  .mt-sp-n5,
  .my-sp-n5 {
    margin-top: -5rem !important;
  }
  .mr-sp-n5,
  .mx-sp-n5 {
    margin-right: -5rem !important;
  }
  .mb-sp-n5,
  .my-sp-n5 {
    margin-bottom: -5rem !important;
  }
  .ml-sp-n5,
  .mx-sp-n5 {
    margin-left: -5rem !important;
  }
  .m-sp-auto {
    margin: auto !important;
  }
  .mt-sp-auto,
  .my-sp-auto {
    margin-top: auto !important;
  }
  .mr-sp-auto,
  .mx-sp-auto {
    margin-right: auto !important;
  }
  .mb-sp-auto,
  .my-sp-auto {
    margin-bottom: auto !important;
  }
  .ml-sp-auto,
  .mx-sp-auto {
    margin-left: auto !important;
  }
  .offset-sp-0 {
    margin-left: 0;
  }
  .offset-sp-1 {
    margin-left: 8.3333333333%;
  }
  .offset-sp-2 {
    margin-left: 16.6666666667%;
  }
  .offset-sp-3 {
    margin-left: 25%;
  }
  .offset-sp-4 {
    margin-left: 33.3333333333%;
  }
  .offset-sp-5 {
    margin-left: 41.6666666667%;
  }
  .offset-sp-6 {
    margin-left: 50%;
  }
  .offset-sp-7 {
    margin-left: 58.3333333333%;
  }
  .offset-sp-8 {
    margin-left: 66.6666666667%;
  }
  .offset-sp-9 {
    margin-left: 75%;
  }
  .offset-sp-10 {
    margin-left: 83.3333333333%;
  }
  .offset-sp-11 {
    margin-left: 91.6666666667%;
  }
}
.hero {
  position: relative;
}

.hero_bg {
  position: relative;
}

.hero_text {
  position: absolute;
  left: 4%;
  width: 51%;
  top: 20%;
  mix-blend-mode: multiply;
}
@media only screen and (max-width: 630px) {
  .hero_text {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    left: 3%;
    width: 55%;
    top: 20%;
  }
}

.scroll_text_wrap {
  width: 100%;
  overflow: hidden;
  position: relative;
}
.scroll_text_wrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(45deg, rgba(187, 45, 244, 0.7) 0%, rgba(255, 25, 244, 0) 100%);
  mix-blend-mode: screen;
  z-index: 2;
}

.scroll_text {
  font-size: 9.7rem;
  white-space: nowrap;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  color: #52cbd8;
  animation: scrollTextRightToLeft 30s linear infinite;
  line-height: 1.2;
}
@media only screen and (max-width: 630px) {
  .scroll_text {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 6.7rem;
  }
}

@keyframes scrollTextRightToLeft {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(-200%);
  }
}
.top_greeting {
  background-image: url("../img/top/deco_line_top.png"), url("../img/top/deco_line_bottom.png");
  background-repeat: no-repeat;
  background-position: top left 0, bottom right 0;
  padding: 20px;
}
@media only screen and (max-width: 630px) {
  .top_greeting {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    background-size: 30vw;
  }
}

.top_greeting_p_wrap {
  max-width: 90%;
  margin: 0 auto;
}
@media only screen and (max-width: 630px) {
  .top_greeting_p_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 100%;
  }
}
.top_greeting_p_wrap .top_greeting_p {
  line-height: 2.1;
}

.top_plan {
  background-image: url("../img/base/wh_grd_bg.png"), url("../img/base/wh_grd_bg_bottom.png"), url("../img/base/plan_bg.webp");
  background-position: top center, bottom center, center;
  background-repeat: no-repeat;
  background-size: 100%, 100%, cover;
}

.top_plan_slider_item {
  margin-bottom: 20px;
  padding: 8px;
}

.top_plan_wrap {
  width: 75%;
  position: relative;
}
@media only screen and (max-width: 630px) {
  .top_plan_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 90%;
  }
}

.slick-dots {
  bottom: -10px !important;
}

.top_plan_info_area {
  display: flex;
  justify-content: end;
  z-index: 10;
  margin-top: -20%;
}

.sideline_ttl {
  padding-left: 10px;
  border-left: 5px solid #52cbd8;
  margin-bottom: 15px;
}
@media only screen and (max-width: 630px) {
  .sideline_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 5px;
    border-left: 3px solid #52cbd8;
  }
}
.sideline_ttl .plan_sideline_ttl_en {
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  margin-bottom: 10px;
  color: #52cbd8;
  font-size: 1.6rem;
}
.sideline_ttl .plan_sideline_ttl_ja {
  font-size: 3rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  .sideline_ttl .plan_sideline_ttl_ja {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
  }
}

#top_plan_slider {
  position: relative;
}

.slide-arrow {
  background-color: transparent;
  max-width: 50px;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 20;
}
@media only screen and (max-width: 630px) {
  .slide-arrow {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 35px;
  }
}

.next-arrow {
  right: -10px;
}

.prev-arrow {
  left: -10px;
  transform: rotate(180deg);
}

.top_plan_info_wrap {
  padding: 30px;
  background-color: #ffffff;
  box-shadow: 5px 5px rgba(82, 203, 216, 0.2);
  width: 75%;
}
@media only screen and (max-width: 630px) {
  .top_plan_info_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 95%;
    padding: 20px;
  }
}

.benefit16 {
  max-width: 230px;
}
@media only screen and (max-width: 630px) {
  .benefit16 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 180px;
  }
}

.top_plan_info_p {
  font-weight: 200;
  color: #4d4d4d;
  margin-bottom: 10px;
}
@media only screen and (max-width: 630px) {
  .top_plan_info_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    line-height: 1.4;
    margin: 15px 0px;
  }
}

.top_plan_info_wrap.color-buy {
  box-shadow: 5px 5px rgba(251, 146, 182, 0.2);
}
.top_plan_info_wrap.color-buy .sideline_ttl {
  border-left: 3px solid #fb92b6;
}
.top_plan_info_wrap.color-buy .plan_sideline_ttl_en {
  color: #fb92b6;
}

.top_plan_info_wrap.color-remake {
  box-shadow: 5px 5px rgba(151, 156, 228, 0.2);
}
.top_plan_info_wrap.color-remake .sideline_ttl {
  border-left: 3px solid #8b92e4;
}
.top_plan_info_wrap.color-remake .plan_sideline_ttl_en {
  color: #8b92e4;
}

.top_plan_info_wrap.color-photo {
  box-shadow: 5px 5px rgba(129, 210, 155, 0.2);
}
.top_plan_info_wrap.color-photo .sideline_ttl {
  border-left: 3px solid #81d29b;
}
.top_plan_info_wrap.color-photo .plan_sideline_ttl_en {
  color: #81d29b;
}

.viewmore {
  display: block;
  position: relative;
  padding-right: 20px;
  text-align: right;
  margin-top: 10px;
  color: #4d4d4d;
  font-size: 1.6rem;
}
@media only screen and (max-width: 630px) {
  .viewmore {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.4rem;
  }
}
.viewmore::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -35px;
  transform: translateY(-50%);
  width: 45px;
  height: 1px;
  background-color: #ccc;
}
@media only screen and (max-width: 630px) {
  .viewmore::after {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 30px;
    right: -15px;
  }
}
.viewmore::before {
  content: "";
  position: absolute;
  top: 50%;
  right: -35px;
  transform: translateY(-50%);
  width: 45px;
  height: 1px;
  background-color: #52cbd8;
  z-index: 2;
  animation: viewmore-scroll-horizontal 2s infinite;
}
@media only screen and (max-width: 630px) {
  .viewmore::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 30px;
    right: -15px;
  }
}

@keyframes viewmore-scroll-horizontal {
  0% {
    transform: translateY(-50%) scaleX(0);
    transform-origin: left center;
    opacity: 1;
  }
  50% {
    transform: translateY(-50%) scaleX(1);
    transform-origin: left center;
    opacity: 1;
  }
  51% {
    transform: translateY(-50%) scaleX(1);
    transform-origin: right center;
    opacity: 1;
  }
  100% {
    transform: translateY(-50%) scaleX(0);
    transform-origin: right center;
    opacity: 1;
  }
}
.top_event_wrap {
  position: relative;
}

.top_event {
  background-image: url("../img/top/star_bottom.png"), url("../img/top/triangle_bg_left.png");
  background-size: 150px, 20vw;
  background-position: bottom left, top left;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 630px) {
  .top_event {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    background-size: 100px, 200px;
  }
}

.campaign_present2_image_wrap {
  padding-bottom: 10px;
  background-image: url(../img/top/campaign_present2.webp);
  height: 320px;
  background-size: 105%;
  background-repeat: no-repeat;
  background-position: bottom 0 right -50px;
  margin-bottom: 50px;
}
@media only screen and (max-width: 630px) {
  .campaign_present2_image_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    height: 50vw;
    background-size: 110%;
    background-position: bottom 5px right -30px;
    padding: 0px 15px 0px 0px;
  }
}

.campaign_present3_image_wrap {
  padding: 25px 25px 0px 70px;
}
@media only screen and (max-width: 630px) {
  .campaign_present3_image_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px 15px 0px 0px;
    right: -20px;
    width: 105%;
  }
}

.event_day {
  max-width: 300px;
  margin-top: 40px;
  z-index: 9;
}

.event1 {
  position: relative;
  z-index: 0;
  max-width: 600px;
}
@media only screen and (max-width: 630px) {
  .event1 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 107%;
  }
}
.event1::before {
  content: "aaa";
  display: block;
  position: absolute;
  background-image: url("../img/top/star_right.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 100px;
  height: 100px;
  inset: 0;
  margin: auto;
  z-index: 55;
}

.event2 {
  max-width: 600px;
  padding: 0px 20px;
}
@media only screen and (max-width: 630px) {
  .event2 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 0;
  }
}

.top_event_img_wrap {
  display: flex;
  justify-content: center;
  position: relative;
}
.top_event_img_wrap:first-child::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/top/top_star_bg.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center right;
  width: 150px;
  height: 150px;
  top: -50px;
  right: 0px;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  .top_event_img_wrap:first-child::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 100px;
    height: 100px;
  }
}

.campaign_ttl {
  font-size: 3.2rem;
  padding: 15px 20px 15px 65px;
  color: #ffffff;
  background-color: #52cbd8;
  text-align: center;
  position: relative;
}
@media only screen and (max-width: 630px) {
  .campaign_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.5rem;
    padding: 10px 20px 10px 65px;
  }
}
.campaign_ttl::before {
  content: "";
  position: absolute;
  top: -30px;
  left: 15px;
  width: 140px;
  height: 140px;
  pointer-events: none;
  background-image: url("../img/top/campaign_1.png");
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 2;
}
@media only screen and (max-width: 630px) {
  .campaign_ttl::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 100px;
    height: 80px;
    left: 5px;
  }
}

.campaign_ttl.num2::before {
  background-image: url("../img/top/campaign_2.png");
}

.campaign_ttl.num3::before {
  background-image: url("../img/top/campaign_3.png");
}

.campaign_bg {
  background: linear-gradient(45deg, rgba(124, 200, 213, 0.2) 13%, rgba(122, 228, 202, 0.2) 91%);
}

.campaign_sub_p {
  font-size: 2.4rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  color: #4d4d4d;
  text-align: center;
  margin-bottom: 30px;
}
@media only screen and (max-width: 630px) {
  .campaign_sub_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
    margin-bottom: 20px;
  }
}

.campaign_attention {
  color: #4d4d4d;
}

.top_collection {
  background-image: url("../img/top/square_bg_left.png");
  background-repeat: no-repeat;
  background-position: top right;
  background-size: 150px;
  position: relative;
  background-color: #fff;
}
@media only screen and (max-width: 630px) {
  .top_collection {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    background-size: 100px;
    background-position: top right -20px;
  }
}

#collection_slider img,
#collection_slider2 img {
  padding: 5px;
}

.button_wrap.blank a.button::before {
  background-image: url(../img/base/ico_blank.svg);
}
.button_wrap.blank a.button::before:hover {
  transform: scale(1);
}

.top_lelien {
  background-color: #f7f7f0;
}

#front-page .campaign {
  display: none;
}

#page-purchase .feature_ttl_area .feature_ttl_lead {
  color: #fb92b6;
}
#page-purchase .feature_ttl_area .feature_num_wrap {
  border-right: 1px solid #fb92b6;
}
@media only screen and (max-width: 630px) {
  #page-purchase .feature_ttl_area .feature_num_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-right: none;
    border-bottom: 1px solid #fb92b6;
  }
}
#page-purchase .plan_box_wrap.purchase {
  border: 2px solid #fb92b6;
}
#page-purchase .plan_box_wrap.purchase .plan_box_ttl_wrap {
  background-color: #fb92b6;
}
#page-purchase .plan_box_wrap.purchase .plan_box_ttl_wrap::before {
  position: absolute;
  right: 0;
  bottom: 0;
  content: "";
  border-top: 15px solid transparent;
  border-left: 15px solid transparent;
  border-right: 15px solid #fa6f9f;
  border-bottom: 15px solid #fa6f9f;
  box-sizing: border-box;
}
#page-purchase .plan_box_wrap.purchase .plan_box_ttl_wrap::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  border-top: 15px solid #fa6f9f;
  border-left: 15px solid #fa6f9f;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  box-sizing: border-box;
}
#page-purchase .plan_box_wrap.purchase .plan_price_item_ttl {
  background-color: #fb92b6;
}
#page-purchase .plan_box_wrap.purchase .item_list.open {
  border-bottom: 1px solid #fb92b6;
}
#page-purchase .plan_box_wrap.purchase .item_list.open ul li::before {
  background-color: #fb92b6;
}
#page-purchase .text_decoration {
  border-bottom: 1px solid #fb92b6;
}
#page-purchase .plus_img_wrap .plusline {
  border: 1px solid #000;
  width: 100%;
}
#page-purchase .plus_img_wrap .second_line {
  transform: rotate(90deg);
}
#page-purchase .cross.purchase::before, #page-purchase .cross.purchase::after {
  background-color: #fb92b6;
}

#page-remake .feature_ttl_area .feature_ttl_lead {
  color: #8b92e4;
}
#page-remake .feature_ttl_area .feature_num_wrap {
  border-right: 1px solid #8b92e4;
}
@media only screen and (max-width: 630px) {
  #page-remake .feature_ttl_area .feature_num_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-right: none;
    border-bottom: 1px solid #8b92e4;
  }
}
#page-remake .plan_free_price_box {
  padding: 20px 30px 30px 30px;
  background: rgb(255, 255, 209);
  margin-bottom: 40px;
}
#page-remake .plan_free_price_ttl {
  font-size: 2.4rem;
  color: #8b92e4;
  text-align: center;
  margin-bottom: 10px;
}
@media only screen and (max-width: 630px) {
  #page-remake .plan_free_price_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
  }
}
#page-remake .text_decoration {
  border-bottom: 1px solid #8b92e4;
}
#page-remake .plan_box_wrap.remakerental {
  border: 2px solid #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .plan_box_ttl_wrap {
  background-color: #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .plan_box_ttl_wrap::before {
  border-right: 15px solid #6d75d6;
  border-bottom: 15px solid #6d75d6;
}
#page-remake .plan_box_wrap.remakerental .plan_box_ttl_wrap::after {
  border-top: 15px solid #6d75d6;
  border-left: 15px solid #6d75d6;
}
#page-remake .plan_box_wrap.remakerental .cross::before, #page-remake .plan_box_wrap.remakerental .cross::after {
  background-color: #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .plan_price_item_ttl {
  background-color: #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .item_list.open {
  border-bottom: 1px solid #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .item_list.open ul li::before {
  background-color: #8b92e4;
}
#page-remake .plan_box_wrap.remakerental .plan_box_ttl {
  font-size: 2.8rem;
}
@media only screen and (max-width: 630px) {
  #page-remake .plan_box_wrap.remakerental .plan_box_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    line-height: 1.4;
  }
}
#page-remake .plan_box_wrap.arrange {
  border: 2px solid #aca2e8;
}
#page-remake .plan_box_wrap.arrange .plan_box_ttl_wrap {
  background-color: #aca2e8;
}
#page-remake .plan_box_wrap.arrange .plan_box_ttl_wrap::before {
  position: absolute;
  right: 0;
  bottom: 0;
  content: "";
  border-top: 15px solid transparent;
  border-left: 15px solid transparent;
  border-right: 15px solid #9085d6;
  border-bottom: 15px solid #9085d6;
  box-sizing: border-box;
}
#page-remake .plan_box_wrap.arrange .plan_box_ttl_wrap::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  border-top: 15px solid #9085d6;
  border-left: 15px solid #9085d6;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  box-sizing: border-box;
}
#page-remake .plan_box_wrap.arrange .plan_price_item_ttl {
  background-color: #aca2e8;
}
#page-remake .plan_box_wrap.arrange .item_list.open {
  border-bottom: 1px solid #aca2e8;
  gap: 30px;
}
#page-remake .plan_box_wrap.arrange .item_list.open ul li::before {
  background-color: #aca2e8;
}
#page-remake .plan_box_wrap.cleaning {
  border: 2px solid #b593e2;
}
#page-remake .plan_box_wrap.cleaning .plan_box_ttl_wrap {
  background-color: #b593e2;
}
#page-remake .plan_box_wrap.cleaning .plan_box_ttl_wrap::before {
  position: absolute;
  right: 0;
  bottom: 0;
  content: "";
  border-top: 15px solid transparent;
  border-left: 15px solid transparent;
  border-right: 15px solid #9f79d1;
  border-bottom: 15px solid #9f79d1;
  box-sizing: border-box;
}
#page-remake .plan_box_wrap.cleaning .plan_box_ttl_wrap::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  border-top: 15px solid #9f79d1;
  border-left: 15px solid #9f79d1;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  box-sizing: border-box;
}
#page-remake .plan_box_wrap.cleaning .plan_price_item_ttl {
  background-color: #b593e2;
}
#page-remake .plan_box_wrap.cleaning .item_list.open {
  border-bottom: 1px solid #b593e2;
}
#page-remake .plan_box_wrap.cleaning .item_list.open ul li::before {
  background-color: #b593e2;
}
#page-remake .plan_box_wrap.cleaning .cleaning_price {
  max-width: 300px;
}
#page-remake .plan_free_price_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
@media only screen and (max-width: 630px) {
  #page-remake .plan_free_price_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: block;
  }
}
#page-remake .free_area {
  display: flex;
  align-items: center;
  justify-content: center;
  grid-row: 1/3;
  padding: 30px;
  background-color: #ffffff;
  font-size: 4.3rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  color: #8b92e4;
  text-align: center;
  outline-offset: -5px;
  outline: 2px solid #8b92e4;
}
@media only screen and (max-width: 630px) {
  #page-remake .free_area {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px;
    font-size: 3.3rem;
  }
}
#page-remake .ico_quote {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background-color: #8b92e4;
  color: #ffffff;
  font-size: 2rem;
  font-weight: 400;
  background-image: url(../img/plan/ico_note.webp);
  background-repeat: no-repeat;
  background-position: left 20px center;
  background-size: 28px;
  grid-row: 1/2;
}
@media only screen and (max-width: 630px) {
  #page-remake .ico_quote {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px 20px;
    margin-bottom: 5px;
    background-size: 20px;
  }
}
#page-remake .ico_search {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background-color: #8b92e4;
  color: #ffffff;
  font-size: 2rem;
  font-weight: 400;
  background-image: url(../img/plan/ico_search.webp);
  background-repeat: no-repeat;
  background-position: left 20px center;
  background-size: 28px;
  grid-row: 2/3;
}
@media only screen and (max-width: 630px) {
  #page-remake .ico_search {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px 20px;
    margin-bottom: 5px;
    background-size: 20px;
  }
}

#page-studio .breadcrumb {
  opacity: 0.7;
}
#page-studio .breadcrumb li {
  color: #ffffff;
}
#page-studio .breadcrumb li a {
  color: #ffffff;
}
#page-studio .breadcrumb li + li::before {
  color: #ffffff;
}
#page-studio .feature_ttl_area .feature_ttl_lead {
  color: #52cbd8;
}
#page-studio .feature_ttl_area .feature_num_wrap {
  border-right: 1px solid #4d4d4d;
}
@media only screen and (max-width: 630px) {
  #page-studio .feature_ttl_area .feature_num_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-right: none;
    border-bottom: 1px solid #4d4d4d;
  }
}
#page-studio .item_list.open {
  gap: 5vw;
}
@media only screen and (max-width: 630px) {
  #page-studio .item_list.open {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    flex-direction: column;
    gap: 0px;
  }
}
#page-studio .plan .plan_box_wrap.photo {
  border: 2px solid #4d4d4d;
}
#page-studio .plan .plan_box_wrap.photo .plan_box_ttl_wrap {
  background-color: #4d4d4d;
}
#page-studio .plan .plan_box_wrap.photo .plan_box_ttl_wrap::before {
  position: absolute;
  right: 0;
  bottom: 0;
  content: "";
  border-top: 15px solid transparent;
  border-left: 15px solid transparent;
  border-right: 15px solid #221815;
  border-bottom: 15px solid #221815;
  box-sizing: border-box;
}
#page-studio .plan .plan_box_wrap.photo .plan_box_ttl_wrap::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  border-top: 15px solid #221815;
  border-left: 15px solid #221815;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  box-sizing: border-box;
}
#page-studio .plan .plan_box_wrap.photo .plan_price_item_ttl {
  background-color: #4d4d4d;
}
#page-studio .plan .plan_box_wrap.photo .item_list.open {
  border-bottom: 1px solid #221815;
}
#page-studio .plan .plan_box_wrap.photo .item_list.open ul li::before {
  background-color: #221815;
}
#page-studio .vertical_image_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
#page-studio .beside_image_wrap {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 80px;
}

#page-campaign .event {
  background-image: url(../img/plan/campaign_bg.webp);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 250px;
}
@media only screen and (max-width: 630px) {
  #page-campaign .event_day {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 200px;
  }
}
#page-campaign .event_item_ttl_lead {
  font-size: 2.4rem;
  color: #ffffff;
}
@media only screen and (max-width: 630px) {
  #page-campaign .event_item_ttl_lead {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
  }
}
#page-campaign .event_item_p {
  font-size: 1.6rem;
  line-height: 1.4;
}
#page-campaign .event_item_ttl_wrap {
  background: linear-gradient(45deg, rgb(124, 200, 213) 13%, rgb(122, 228, 202) 91%);
  text-align: center;
  padding: 20px 20px 25px 20px;
  position: relative;
}
#page-campaign .badge {
  position: absolute;
  max-width: 100px;
  top: -20px;
  left: 20px;
}
@media only screen and (max-width: 630px) {
  #page-campaign .badge {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 70px;
    left: 10px;
  }
}
#page-campaign .event_item_ttl {
  font-size: 5.5rem;
  color: #ffff8f;
  font-weight: 500;
  font-family: notosans, sans-serif;
  line-height: 1.3;
  margin-bottom: 5px;
}
@media only screen and (max-width: 630px) {
  #page-campaign .event_item_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 4rem;
  }
}
#page-campaign .wh {
  color: #ffffff;
}
#page-campaign .event_medium_ttl {
  font-size: 2.6rem;
  padding: 20px;
  text-align: center;
  line-height: 1;
  border-bottom: 2px solid #52cbd8;
  border-top: 2px solid #52cbd8;
  position: relative;
}
@media only screen and (max-width: 630px) {
  #page-campaign .event_medium_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2rem;
  }
}
#page-campaign .event_medium_ttl::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 1px;
  top: 3px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #52cbd8;
}
#page-campaign .event_medium_ttl::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 1px;
  bottom: 3px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #52cbd8;
}
#page-campaign .event_medium_ttl .event_medium_ttl_en {
  font-size: 1.6rem;
  color: #52cbd8;
}
#page-campaign .lineup_item_ttl {
  padding: 20px;
  background-color: #ffffdc;
  text-align: center;
  font-size: 2.9rem;
  border-right: 4px solid #52cbd8;
  border-left: 4px solid #52cbd8;
  margin: 30px 0px;
  position: relative;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  #page-campaign .lineup_item_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
    font-weight: 500;
  }
}
#page-campaign .lineup_item_ttl::after {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/campaign/people_3.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 80px;
  height: 80px;
  right: -10px;
  bottom: -10px;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  #page-campaign .lineup_item_ttl::after {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 50px;
    height: 50px;
  }
}
#page-campaign .lineup_item_ttl strong {
  font-size: 3.8rem;
  margin: 0px 4px;
}
#page-campaign .lineup_item_ttl.ticket::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/campaign/ticket_image.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 240px;
  height: 175px;
  left: -35px;
  bottom: 25px;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  #page-campaign .lineup_item_ttl.ticket::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 180px;
    height: 150px;
  }
}
#page-campaign .lineup_item_ttl.people10::after {
  background-image: url("../img/campaign/people_10.webp");
}
#page-campaign .application {
  font-size: 2.7rem;
  text-align: center;
  line-height: 1.3;
  margin: 30px 0px;
  font-weight: 300;
}
@media only screen and (max-width: 630px) {
  #page-campaign .application {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
  }
}
#page-campaign .application small {
  font-size: 1.8rem;
}
#page-campaign .application .asterisk {
  font-size: 1.5rem;
  color: #4d4d4d;
}
#page-campaign .campaign_lead_p {
  font-size: 1.6rem;
  color: #4d4d4d;
  margin-bottom: 20px;
}
#page-campaign .event_item_area2 {
  background-image: url(../img/campaign/campaign_star_bottom.webp);
  background-repeat: no-repeat;
  background-size: 200px;
  background-position: bottom -50px left;
}
@media only screen and (max-width: 630px) {
  #page-campaign .event_item_area2 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    background-size: 100px;
    background-position: bottom 80px left;
  }
}
#page-campaign .campaign_item_ttl {
  font-size: 3.3rem;
  color: #ffffff;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  background-color: #52cbd8;
  text-align: center;
  padding: 15px 20px;
  position: relative;
}
@media only screen and (max-width: 630px) {
  #page-campaign .campaign_item_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
    padding: 15px 20px 15px 70px;
  }
}
#page-campaign .campaign_item_badge {
  position: absolute;
  width: 140px;
  left: 10px;
  top: -30px;
  z-index: 10;
}
@media only screen and (max-width: 630px) {
  #page-campaign .campaign_item_badge {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 25vw;
    max-width: 100px;
    top: -25px;
    height: auto;
  }
}
#page-campaign .campaign_item_bg_wrap {
  background-image: linear-gradient(45deg, rgba(124, 200, 213, 0.3) 13%, rgba(122, 228, 202, 0.3) 91%);
  margin-bottom: 60px;
}
#page-campaign .campaign_item_p {
  font-size: 2.4rem;
  color: #4d4d4d;
  text-align: center;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  #page-campaign .campaign_item_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.8rem;
    margin-bottom: 10px;
  }
}
#page-campaign .campaign_present {
  padding: 30px;
}
@media only screen and (max-width: 630px) {
  #page-campaign .campaign_present {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 0px;
  }
}
#page-campaign .campaign_present3_image_wrap {
  padding: 25px 25px 0px 70px;
  position: relative;
}
#page-campaign .campaign_present3_image_wrap::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/plan/triangle_bg.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 250px;
  height: 250px;
  top: 0;
  right: -20px;
  margin: auto;
}
#page-campaign .campaign_present3_image_wrap::after {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/top/square_bg_left.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 250px;
  height: 250px;
  bottom: 0;
  left: -100px;
  margin: auto;
  z-index: -1;
}
@media only screen and (max-width: 630px) {
  #page-campaign .campaign_present3_image_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px 15px 0px 0px;
    right: -20px;
    width: 105%;
  }
}

#page-about .vertical_ttl {
  writing-mode: vertical-rl;
}
@media only screen and (max-width: 630px) {
  #page-about .vertical_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px;
    padding-top: 0px;
  }
}
#page-about .shop_greeting {
  background: repeating-linear-gradient(transparent 50%, rgb(247, 247, 240) 50%);
  background: linear-gradient(to bottom, transparent 0%, transparent 23%, rgb(247, 247, 240) 23%, rgb(247, 247, 240) 100%);
}
#page-about .shop_greeting_ttl_wrap {
  display: flex;
  justify-content: space-between;
}
#page-about .shop_greeting_ttl_wrap .shop_img_wrap {
  max-width: 350px;
  align-self: flex-end;
  width: 75%;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_greeting_ttl_wrap .shop_img_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 70%;
  }
}
#page-about .shop_greeting_ttl_wrap .vertical_ttl {
  width: 25%;
}
#page-about .shop_message_wrap {
  width: 63%;
  margin-top: -150px;
  box-shadow: 8px 8px 0px 0px rgba(82, 203, 216, 0.4);
}
@media only screen and (max-width: 630px) {
  #page-about .shop_message_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 80%;
    margin-top: -80px;
  }
}
#page-about .shop_message_info {
  padding: 40px;
  background-color: #ffffff;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_message_info {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 25px;
  }
}
#page-about .shop_message_info .shop_message_ttl {
  display: block;
  font-size: 2.5rem;
  border-bottom: 1px solid #52cbd8;
  color: #4d4d4d;
  padding-bottom: 20px;
  margin-bottom: 20px;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_message_info .shop_message_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2rem;
  }
}
#page-about .key-color {
  color: #52cbd8;
}
#page-about .shop_message_info_p {
  font-size: 1.9rem;
  text-align: right;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_message_info_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: flex;
    flex-direction: column;
    font-size: 1.6rem;
  }
}
#page-about .shop_message_info_p_en {
  font-size: 1.6rem;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  margin-right: 5px;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_message_info_p_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    order: 2;
  }
}
#page-about .shop_message_p {
  font-size: 1.6rem;
  color: #4d4d4d;
  line-height: 1.9;
  padding: 40px 10px;
}
#page-about .info_table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 40px;
  margin-bottom: 50px;
}
@media only screen and (max-width: 630px) {
  #page-about .info_table {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-top: 0px;
  }
}
#page-about .info_table tr {
  border-bottom: 1px solid #ddd;
}
#page-about .info_table th,
#page-about .info_table td {
  text-align: left;
  padding: 18px;
  vertical-align: top;
}
@media only screen and (max-width: 630px) {
  #page-about .info_table th,
  #page-about .info_table td {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 100%;
    display: block;
  }
}
#page-about .info_table th {
  font-weight: 400;
  color: #333;
  width: 30%;
  white-space: nowrap;
  border-bottom: 2px solid #52cbd8; /* 左の水色ライン */
}
@media only screen and (max-width: 630px) {
  #page-about .info_table th {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px 18px 5px 18px;
    width: 100%;
  }
}
#page-about .info_table td {
  color: #444;
}
@media only screen and (max-width: 630px) {
  #page-about .info_table td {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 5px 18px 20px 18px;
  }
}
#page-about .info_map {
  margin-top: 30px;
}
#page-about .reason_ttl {
  font-size: 3rem;
  font-weight: 400;
  color: #ffffff;
  padding: 15px 20px;
  background: linear-gradient(45deg, rgb(124, 200, 213) 13%, rgb(122, 228, 202) 91%);
  text-align: center;
}
@media only screen and (max-width: 630px) {
  #page-about .reason_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.6rem;
  }
}
#page-about .reason_ttl .reason_strong {
  color: #ffff8f !important;
}
#page-about .reason_ttl .reason_num {
  font-size: 5rem;
  margin: 0px 5px;
  line-height: 1;
}
#page-about .triangle {
  position: relative;
}
#page-about .triangle::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/about/triangle_bg.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 300px;
  height: 300px;
  right: -40px;
  top: 40px;
  margin: auto;
}
#page-about .triangle2 {
  position: relative;
}
#page-about .triangle2::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/about/triangle_bg_2.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 400px;
  height: 300px;
  right: -40px;
  bottom: -80px;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  #page-about .triangle2::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    bottom: -140px;
  }
}
#page-about .triangle2::after {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/about/dotted_bg2.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 200px;
  height: 200px;
  right: -30px;
  top: 90px;
  margin: auto;
  z-index: -1;
}
@media only screen and (max-width: 630px) {
  #page-about .triangle2::after {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 100px;
    height: 100px;
    right: -30px;
    top: 150px;
  }
}
#page-about .reason_item_wrap {
  margin-bottom: 40px;
}
#page-about .reason_item_wrap .reason_img {
  width: 90px;
  margin-bottom: 10px;
  margin-left: -8px;
}
@media only screen and (max-width: 630px) {
  #page-about .reason_item_wrap .reason_img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 65px;
  }
}
#page-about .reason_item_wrap .reason_item_border_wrap {
  border-left: 1px solid #52cbd8;
  padding-left: 20px;
}
#page-about .reason_item_wrap .reason_item_border_wrap .reason_item_ttl {
  font-size: 3rem;
  color: #4d4d4d;
  margin-bottom: 5px;
}
@media only screen and (max-width: 630px) {
  #page-about .reason_item_wrap .reason_item_border_wrap .reason_item_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
  }
}
#page-about .reason_item_wrap .reason_item_border_wrap .reason_item_p {
  font-size: 1.6rem;
  color: #4d4d4d;
  margin-bottom: 15px;
}
#page-about .reason_img_wrap {
  position: relative;
}
#page-about .reason_img_wrap::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: -25px;
  right: -30px;
  margin: auto;
  background-image: radial-gradient(circle, #06b6d4 2px, transparent 2px);
  background-position: 0 0;
  background-size: 10px 10px;
}
@media only screen and (max-width: 630px) {
  #page-about .reason_img_wrap::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    bottom: -20px;
    right: -20px;
  }
}
#page-about .partner {
  background-color: #f7f7f0;
}
#page-about .partner_lead_p {
  font-size: 1.4rem;
  color: #4d4d4d;
}
#page-about .area_btn_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 35px;
}
@media only screen and (max-width: 630px) {
  #page-about .area_btn_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    grid-template-columns: 1fr;
    padding: 25px;
    gap: 0px;
  }
}
#page-about .area_btn_wrap .button_wrap > .button {
  width: 100%;
}
#page-about .area_wrap {
  padding: 30px;
  background-color: #ffffff;
  margin-bottom: 40px;
}
#page-about .area_ttl {
  font-size: 2.6rem;
  padding: 20px;
  text-align: center;
  line-height: 1;
  border-bottom: 2px solid #52cbd8;
  border-top: 2px solid #52cbd8;
  position: relative;
  margin-bottom: 30px;
}
@media only screen and (max-width: 630px) {
  #page-about .area_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2rem;
  }
}
#page-about .area_ttl::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 1px;
  top: 3px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #52cbd8;
}
#page-about .area_ttl::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 1px;
  bottom: 3px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #52cbd8;
}
#page-about .area_medium_ttl {
  padding-left: 15px;
  border-left: 3px solid #52cbd8;
  font-size: 2.3rem;
  color: #4d4d4d;
  margin-bottom: 20px;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  margin-top: 60px;
}
@media only screen and (max-width: 630px) {
  #page-about .area_medium_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2rem;
    padding-left: 10px;
    margin-bottom: 10px;
    margin-top: 40px;
  }
}
#page-about .shop_name {
  display: inline-block;
  color: #52cbd8;
  border-bottom: 1px solid #52cbd8;
  padding-bottom: 2px;
  margin-bottom: 10px;
  font-size: 1.9rem;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_name {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.7rem;
  }
}
#page-about .shop_add {
  font-size: 1.6rem;
  color: #4d4d4d;
}
#page-about .shop_tel {
  padding-left: 32px;
  position: relative;
}
#page-about .shop_tel::before {
  content: "tel.";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  color: #4d4d4d;
}
#page-about .shop_item_area {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  row-gap: 35px;
}
@media only screen and (max-width: 630px) {
  #page-about .shop_item_area {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    grid-template-columns: 1fr;
    row-gap: 25px;
  }
}
#page-about .btn_grd {
  display: block;
  padding: 10px 35px 10px 20px;
  background: linear-gradient(45deg, rgb(124, 200, 213) 13%, rgb(122, 228, 202) 91%);
  color: #ffffff;
  margin-top: 10px;
  text-align: center;
  background-repeat: no-repeat;
  position: relative;
}
#page-about .btn_grd::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/base/ico_blank_wh.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 20px;
  height: 18px;
  right: 15px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  #page-about .btn_grd {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.4rem;
  }
}
#page-about .payment_p_ttl {
  font-size: 1.8rem;
  text-align: center;
}
#page-about .payment_p {
  font-size: 1.5rem;
  margin-bottom: 110px;
}
@media only screen and (max-width: 630px) {
  #page-about .payment_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 50px;
  }
}
#page-about .payment_p.fit {
  width: fit-content;
  margin: 0 auto 110px auto;
}
@media only screen and (max-width: 630px) {
  #page-about .payment_p.fit {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin: 0 auto 50px auto;
  }
}
#page-about .payment_wrap {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
}
#page-about .payment_wrap_emoney {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: 100%;
}
#page-about .dotted {
  position: relative;
}
#page-about .dotted::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/about/dotted_bg.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 220px;
  height: 220px;
  right: -40px;
  bottom: -70px;
  margin: auto;
}

#page-privacy .privacy {
  max-width: 900px;
  margin: 0 auto;
  padding: 2rem 1rem;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  line-height: 1.7;
}
#page-privacy .privacy_title {
  font-size: 2.4rem;
  text-align: center;
  margin-bottom: 2rem;
  font-weight: bold;
  color: #222;
}
#page-privacy .privacy_intro {
  margin-bottom: 2rem;
}
#page-privacy .privacy_section {
  margin-bottom: 2.5rem;
}
#page-privacy .privacy_section h2 {
  font-size: 2rem;
  margin-bottom: 10px;
  color: #444;
  border-left: 4px solid #52cbd8;
  padding-left: 0.6rem;
  font-weight: bold;
}
#page-privacy .privacy_section p {
  margin-bottom: 1rem;
}
#page-privacy .privacy_links {
  margin: 1rem 0;
  padding-left: 1.2rem;
}
#page-privacy .privacy_links li {
  margin-bottom: 0.5rem;
}
#page-privacy .privacy_links li a {
  color: #0066cc;
  text-decoration: underline;
}
#page-privacy .privacy_links li a:hover {
  color: #004080;
}
#page-privacy .privacy_contact {
  background: #f9f9f9;
  border: 1px solid #ddd;
  padding: 1rem;
  border-radius: 6px;
}
#page-privacy .privacy_contact p {
  margin-bottom: 1rem;
}
#page-privacy .privacy_contact strong {
  font-weight: bold;
  color: #222;
}

.page_header {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  background-image: url(../img/base/page-header_image.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 40px;
}
.page_header .header_ttl_wrap > hgroup {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-weight: 200;
}
.page_header .header_ttl_wrap > hgroup .sparking_img {
  max-width: 20px;
  margin-bottom: 5px;
}
@media only screen and (max-width: 630px) {
  .page_header .header_ttl_wrap > hgroup .sparking_img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 12px;
  }
}
.page_header .header_ttl_wrap > hgroup .header_ttl_en {
  font-size: 8rem;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  font-weight: 100;
  line-height: 0.8;
  margin-bottom: 15px;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  .page_header .header_ttl_wrap > hgroup .header_ttl_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 6rem;
  }
}
.page_header .header_ttl_wrap > hgroup .header_ttl {
  font-size: 2rem;
  color: #52cbd8;
  font-weight: 500;
}

.breadcrumb {
  font-size: 1.4rem;
  margin: 10px 0;
  position: absolute;
  bottom: -40px;
  right: 20px;
  z-index: 10;
}
.breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.breadcrumb li {
  color: #999;
}
.breadcrumb li a {
  color: #999;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.breadcrumb li a:hover {
  opacity: 0.7;
}
.breadcrumb li + li::before {
  content: "›";
  margin: 0 6px;
  color: #999;
}

#page-plan .button_wrap .button {
  width: 80%;
  max-width: 300px;
}
#page-plan .plan {
  background-image: url("../img/base/wh_grd_bg.png"), url("../img/base/wh_grd_bg_bottom.png"), url("../img/plan/plan_bg.webp");
  background-position: top center, bottom center, center;
  background-repeat: no-repeat;
  background-size: 100%, 100%, cover;
}
#page-plan .plan_wrap {
  display: block;
  width: 75%;
  position: relative;
}
#page-plan .plan_wrap.right_box {
  margin-left: auto;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 90%;
  }
}
#page-plan .plan_slider_item {
  padding: 40px;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_slider_item {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px;
  }
}
#page-plan .slick-dots {
  bottom: -10px !important;
}
#page-plan .plan_info_area {
  display: flex;
  justify-content: end;
  z-index: 10;
  margin-top: -20%;
}
#page-plan .plan_info_area.right_box {
  justify-content: flex-start;
}
#page-plan .sideline_ttl {
  padding-left: 10px;
  border-left: 5px solid #52cbd8;
  margin-bottom: 15px;
}
@media only screen and (max-width: 630px) {
  #page-plan .sideline_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 5px;
    border-left: 3px solid #52cbd8;
  }
}
#page-plan .sideline_ttl .plan_sideline_ttl_en {
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
  margin-bottom: 10px;
  color: #52cbd8;
  font-size: 1.6rem;
}
#page-plan .sideline_ttl .plan_sideline_ttl_ja {
  font-size: 3rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  #page-plan .sideline_ttl .plan_sideline_ttl_ja {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.2rem;
  }
}
#page-plan .plan_info_wrap.color-buy {
  box-shadow: 5px 5px rgba(251, 146, 182, 0.2);
}
#page-plan .plan_info_wrap.color-buy .sideline_ttl {
  border-left: 5px solid #fb92b6;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_info_wrap.color-buy .sideline_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-left: 3px solid #fb92b6;
  }
}
#page-plan .plan_info_wrap.color-buy .plan_sideline_ttl_en {
  color: #fb92b6;
}
#page-plan .plan_info_wrap.color-remake {
  box-shadow: 5px 5px rgba(151, 156, 228, 0.2);
}
#page-plan .plan_info_wrap.color-remake .sideline_ttl {
  border-left: 5px solid #8b92e4;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_info_wrap.color-remake .sideline_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-left: 3px solid #8b92e4;
  }
}
#page-plan .plan_info_wrap.color-remake .plan_sideline_ttl_en {
  color: #8b92e4;
}
#page-plan .plan_info_wrap.color-photo {
  box-shadow: 5px 5px rgba(129, 210, 155, 0.2);
}
#page-plan .plan_info_wrap.color-photo .sideline_ttl {
  border-left: 5px solid #81d29b;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_info_wrap.color-photo .sideline_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-left: 3px solid #81d29b;
  }
}
#page-plan .plan_info_wrap.color-photo .plan_sideline_ttl_en {
  color: #81d29b;
}
#page-plan .plan_info_wrap {
  padding: 30px;
  background-color: #ffffff;
  box-shadow: 5px 5px rgba(82, 203, 216, 0.2);
  width: 80%;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_info_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 95%;
    padding: 20px;
  }
}
#page-plan .benefit16 {
  max-width: 230px;
}
@media only screen and (max-width: 630px) {
  #page-plan .benefit16 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 180px;
  }
}
#page-plan .plan_info_p {
  font-weight: 200;
  color: #4d4d4d;
  margin-bottom: 10px;
}
@media only screen and (max-width: 630px) {
  #page-plan .plan_info_p {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    line-height: 1.2;
    margin: 15px 0px;
  }
}
#page-plan #rental {
  position: relative;
}
#page-plan #rental::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/plan/triangle_bg.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: right;
  width: 30vw;
  height: 30vw;
  right: -30px;
  margin: auto;
  z-index: 0;
}
#page-plan #photo {
  position: relative;
}
#page-plan #photo::before {
  content: "";
  display: block;
  position: absolute;
  background-image: url("../img/plan/triangle_bg2.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left;
  width: 35vw;
  height: 35vw;
  left: -30px;
  top: -70px;
  margin: auto;
  z-index: 0;
}

.feature_num {
  padding-right: 20px;
}

.feature_ttl_area {
  display: flex;
  margin-bottom: 10px;
}
@media only screen and (max-width: 630px) {
  .feature_ttl_area {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    display: block;
    margin-bottom: 7px;
  }
}
.feature_ttl_area .feature_ttl_lead {
  color: #52cbd8;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  font-size: 1.8rem;
}
@media only screen and (max-width: 630px) {
  .feature_ttl_area .feature_ttl_lead {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.7rem;
  }
}
.feature_ttl_area .feature_1 {
  font-size: 2.6rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  .feature_ttl_area .feature_1 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.3rem;
  }
}
.feature_ttl_area .feature_num_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 90px;
  padding-right: 10px;
  border-right: 1px solid #52cbd8;
  margin-right: 15px;
}
@media only screen and (max-width: 630px) {
  .feature_ttl_area .feature_num_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding-right: 0px;
    padding-bottom: 5px;
    border-right: none;
    border-bottom: 1px solid #52cbd8;
    max-width: 70px;
    margin-bottom: 15px;
    margin-top: 20px;
  }
}

.feature_p {
  font-size: 1.5rem;
  color: #4d4d4d;
  font-weight: 300;
}

.text_decoration {
  border-bottom: 1px solid #52cbd8;
}

.section_lead_ttl_wrap {
  text-align: center;
  margin-bottom: 15px;
}

.section_lead_ttl {
  display: inline-block;
  font-size: 1.8rem;
  font-weight: bold;
  color: #333;
  background: transparent;
  border-bottom: solid 2px #52cbd8;
  padding: 15px 22px 5px 22px;
  position: relative;
  font-weight: 300;
}
@media only screen and (max-width: 630px) {
  .section_lead_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.7rem;
  }
}
.section_lead_ttl::before {
  content: "";
  position: absolute;
  width: 36px;
  height: 10px;
  background-color: #ffffff;
  bottom: -9px;
  left: 0;
  right: 0;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  z-index: 1;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  .section_lead_ttl::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    background-color: #f4f6f9;
  }
}
.section_lead_ttl::after {
  content: "";
  position: absolute;
  width: 36px;
  height: 10px;
  background: #52cbd8;
  bottom: -11px;
  left: 0;
  right: 0;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: auto;
}

.plan .plan_box_wrap {
  text-align: center;
  border: 2px solid #49b5db;
  background-color: #ffffff;
  margin-bottom: 50px;
}
.plan .plan_box_wrap .plan_box_lead {
  font-size: 1.8rem;
  color: #ffff8f;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_box_lead {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.plan .plan_box_wrap .plan_box_ttl {
  font-size: 3.2rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  color: #ffffff;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_box_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
  }
}
.plan .plan_box_wrap .price_num {
  font-size: 5.8rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  line-height: 1;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .price_num {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 4.5rem;
  }
}
.plan .plan_box_wrap .price_enn {
  font-size: 3.5rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .price_enn {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 3rem;
  }
}
.plan .plan_box_wrap .price_tax {
  font-size: 2.1rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
.plan .plan_box_wrap .price_tax_in {
  font-size: 1.9rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
}
.plan .plan_box_wrap .plan_box_ttl_wrap.badge {
  position: relative;
}
.plan .plan_box_wrap .plan_box_ttl_wrap.badge .no1_badge {
  position: absolute;
  z-index: 10;
  max-width: 100px;
  left: -15px;
  top: -20px;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_box_ttl_wrap.badge .no1_badge {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 18vw;
    top: -35px;
  }
}
.plan .plan_box_wrap .plan_box_ttl_wrap {
  padding: 20px 30px;
  background-color: #49b5db;
  position: relative;
  outline: 1px solid rgb(255, 255, 255);
  outline-offset: -5px; /*outline-offsetの値を-15pxにして内側に調整*/
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_box_ttl_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 20px;
  }
}
.plan .plan_box_wrap .plan_box_ttl_wrap::before {
  position: absolute;
  right: 0;
  bottom: 0;
  content: "";
  border-top: 15px solid transparent;
  border-left: 15px solid transparent;
  border-right: 15px solid #8fd9f2;
  border-bottom: 15px solid #8fd9f2;
  box-sizing: border-box;
}
.plan .plan_box_wrap .plan_box_ttl_wrap::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  border-top: 15px solid #8fd9f2;
  border-left: 15px solid #8fd9f2;
  border-right: 15px solid transparent;
  border-bottom: 15px solid transparent;
  box-sizing: border-box;
}
.plan .plan_box_wrap .plan_box_inner {
  padding: 30px;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_box_inner {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 5vw;
  }
}
.plan .plan_box_wrap .plan_box_inner_lead {
  font-size: 1.8rem;
  margin-bottom: 10px;
  color: #4d4d4d;
  font-weight: 300;
  padding-bottom: 10px;
  border-bottom: 1px solid #ccc;
}
.plan .plan_box_wrap .plan_price_item_ttl {
  font-size: 1.7rem;
  padding: 5px 20px 8px 20px;
  background-color: #49b5db;
  color: #ffffff;
  border-radius: 100vmax;
  background-image: url(../img/plan/ico_under_arrow.svg);
  background-repeat: no-repeat;
  background-position: center right 20px;
  background-size: 15px;
  margin-top: 20px;
  cursor: pointer;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_price_item_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.7rem;
    background-size: 10px;
    padding: 5px 20px 6px 20px;
  }
}
.plan .plan_box_wrap .plan_price_item_ttl .plan_rental_item_num {
  width: 100%;
  font-size: 3rem;
  margin: 0px 5px;
  line-height: 1;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .plan_price_item_ttl .plan_rental_item_num {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
    margin: 0px 3px;
  }
}
.plan .plan_box_wrap .plan_price_item_wrap.open .plan_price_item_ttl {
  background-image: url(../img/plan/ico_under_arrow_rotate.svg);
}
.plan .plan_box_wrap .item_list {
  display: none;
  cursor: pointer;
}
.plan .plan_box_wrap .item_list.open {
  display: flex;
  gap: 10vw;
  justify-content: center;
  padding: 30px;
  border-bottom: 1px solid #29a3cf;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .item_list.open {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 15px;
  }
}
.plan .plan_box_wrap .item_list.open ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.plan .plan_box_wrap .item_list.open ul li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 8px;
  text-align: left;
  font-size: 1.7rem;
}
.plan .plan_box_wrap .item_list.open ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background-color: #29a3cf;
  border-radius: 50%;
}
.plan .plan_box_wrap .cross {
  position: relative;
  width: 30px;
  height: 30px;
  margin: 15px auto 0px auto;
}
.plan .plan_box_wrap .cross::before, .plan .plan_box_wrap .cross::after {
  content: "";
  position: absolute;
  background-color: #52cbd8;
}
.plan .plan_box_wrap .cross::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: 3px;
  transform: translateY(-50%);
}
.plan .plan_box_wrap .cross::after {
  left: 50%;
  top: 0;
  width: 3px;
  height: 100%;
  transform: translateX(-50%);
}
.plan .plan_box_wrap .benefit_image_wrap {
  text-align: center;
}
.plan .plan_box_wrap .benefit_image_wrap > img {
  max-width: 350px;
  margin-right: 10px;
}
@media only screen and (max-width: 630px) {
  .plan .plan_box_wrap .benefit_image_wrap > img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 260px;
  }
}
.plan .plan_box_wrap.standard {
  border: 2px solid #52cbd8;
}
.plan .plan_box_wrap.standard .plan_box_ttl_wrap {
  background-color: #52cbd8;
}
.plan .plan_box_wrap.standard .plan_price_item_ttl {
  background-color: #52cbd8;
}
.plan .plan_box_wrap.standard .item_list.open {
  border-bottom: 1px solid #52cbd8;
}
.plan .plan_box_wrap.standard .item_list.open ul li::before {
  background-color: #52cbd8;
}
.plan .plan_box_wrap.costume {
  border: 2px solid #72d0ca;
}
.plan .plan_box_wrap.costume .plan_box_ttl_wrap {
  background-color: #72d0ca;
}
.plan .plan_box_wrap.costume .plan_price_item_ttl {
  background-color: #72d0ca;
}
.plan .plan_box_wrap.costume .item_list.open {
  border-bottom: 1px solid #72d0ca;
}
.plan .plan_box_wrap.costume .item_list.open ul li::before {
  background-color: #72d0ca;
}
.plan .bdb-none {
  border-bottom: none !important;
}

.hidden {
  overflow: hidden;
}

.benefits {
  background-color: #f7f7f0;
  position: relative;
  margin-top: 100px;
}
@media only screen and (max-width: 630px) {
  .benefits {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-top: 100px;
  }
}

.benefit_img {
  margin: 5px;
}
@media only screen and (max-width: 1024px) {
  .benefit_img {
    /*　画面サイズ $tabWitdh まではここを読み込む　*/
    margin: 0 calc(50% - 50vw);
  }
}
@media only screen and (max-width: 630px) {
  .benefit_img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin: 0 calc(50% - 50vw);
  }
}

.benefits_ttl_img_wrap {
  margin: 0px 10px;
}
@media only screen and (max-width: 630px) {
  .benefits_ttl_img_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    transform: scale(1.1);
  }
}

.round_wrap {
  text-align: center;
  position: absolute;
  top: -90px;
  right: 0;
  left: 0;
  z-index: 9;
}
.round_wrap > img {
  max-width: 400px;
}
@media only screen and (max-width: 630px) {
  .round_wrap > img {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 280px;
    top: 25px;
  }
}

.benefits_wrap {
  padding: 20px;
  text-align: center;
  outline: 2px solid #c7a640;
  outline-offset: -17px; /*outline-offsetの値を-15pxにして内側に調整*/
}
@media only screen and (max-width: 630px) {
  .benefits_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 10px;
    padding-top: 40px;
    outline: 1px solid #c7a640;
    outline-offset: -10px; /*outline-offsetの値を-15pxにして内側に調整*/
  }
}
.benefits_wrap > img {
  max-width: 500px;
}

.benefit_item_p {
  line-height: 1.4;
  font-size: 1.5rem;
}
.benefit_item_p span {
  letter-spacing: -0.01em;
}

.benefit_item_wrap {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  background-color: rgba(199, 166, 64, 0.6);
  gap: 7px;
  padding: 10px;
  max-width: 500px;
  margin: 0 auto;
  margin-top: -80px;
  position: relative;
}
@media only screen and (max-width: 630px) {
  .benefit_item_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    grid-template-columns: 1fr 1fr;
    max-width: 320px;
    margin-top: -20px;
  }
}

@media only screen and (max-width: 630px) {
  .benefit_item_wrap:has(.benefit_album) {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 100px;
  }
}

.benefit_item_wrap2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  justify-content: center;
  background-color: rgba(199, 166, 64, 0.6);
  gap: 7px;
  padding: 10px;
  max-width: 320px;
  margin: 0 auto;
  margin-top: -80px;
}
@media only screen and (max-width: 630px) {
  .benefit_item_wrap2 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-top: -20px;
  }
}

.benefit_item {
  display: flex;
  align-items: center;
  justify-content: space-around;
  flex-direction: column;
  padding: 10px;
  background-color: #fff;
  position: relative;
  min-height: 150px;
}
@media only screen and (max-width: 630px) {
  .benefit_item {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    min-height: 100px;
    aspect-ratio: 1/1;
    padding: 25px;
  }
  .benefit_item.end_item {
    grid-column: 1/3;
    grid-row: 2/3;
    aspect-ratio: auto;
    min-height: 60px;
  }
}
.benefit_item .benefit_ico {
  max-width: 70px;
  margin-top: 25px;
}
.benefit_item .benefit_ico.large {
  max-width: 90px;
}
@media only screen and (max-width: 630px) {
  .benefit_item .benefit_ico {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 70px;
    margin-top: 0px;
  }
}
.benefit_item .num {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #ffffff;
  width: 25px;
  height: 25px;
  border-radius: 100vmax;
  background-color: #4d4d4d;
  position: absolute;
  top: 10px;
  left: 10px;
  line-height: 1;
  padding-bottom: 1px;
}

.grid-2 {
  grid-template-columns: repeat(2, 155px) !important;
  justify-content: center;
  width: fit-content;
}

.benefits_group {
  margin-bottom: 100px;
}
@media only screen and (max-width: 630px) {
  .benefits_group {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin-bottom: 60px;
  }
}

.benefit_album {
  max-width: 250px;
  position: absolute;
  bottom: -50px;
  right: -60px;
}
@media only screen and (max-width: 630px) {
  .benefit_album {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 170px;
    bottom: -140px;
    right: 0px;
  }
}

@media only screen and (max-width: 630px) {
  .pd-sp-0 {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 0 !important;
  }
}

.collection_bloom_wrap {
  max-width: 450px;
  margin: 0 auto;
}

.collection_ban_wrap {
  position: relative;
}
.collection_ban_wrap a {
  display: block;
}
.collection_ban_wrap .collection_ban_label {
  position: absolute;
  top: -20px;
  left: -20px;
  width: 100px;
}
@media only screen and (max-width: 630px) {
  .collection_ban_wrap .collection_ban_label {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    top: -40px;
    left: -20px;
    width: 85px;
  }
}

#flow_slider {
  margin: 0px 30px 0px 30px;
}
@media only screen and (max-width: 630px) {
  #flow_slider {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    margin: 0px;
  }
}

.slide-arrow {
  background-color: transparent;
  max-width: 50px;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 20;
}
@media only screen and (max-width: 630px) {
  .slide-arrow {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    max-width: 35px;
  }
}

.flowcard_wrap {
  padding: 10px;
  margin: 30px;
  border: 2px solid #52cbd8;
  position: relative;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 5px;
    margin: 10px;
  }
}
.flowcard_wrap::before {
  position: absolute;
  right: -10px;
  bottom: -10px;
  content: "";
  border-top: 30px solid transparent;
  border-left: 30px solid transparent;
  border-right: 30px solid #52cbd8;
  border-bottom: 30px solid #52cbd8;
  box-sizing: border-box;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-top: 15px solid transparent;
    border-left: 15px solid transparent;
    border-right: 15px solid #52cbd8;
    border-bottom: 15px solid #52cbd8;
  }
}
.flowcard_wrap::after {
  position: absolute;
  left: -10px;
  top: -10px;
  content: "";
  border-top: 30px solid #52cbd8;
  border-left: 30px solid #52cbd8;
  border-right: 30px solid transparent;
  border-bottom: 30px solid transparent;
  box-sizing: border-box;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap::after {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    border-top: 15px solid #52cbd8;
    border-left: 15px solid #52cbd8;
    border-right: 15px solid transparent;
    border-bottom: 15px solid transparent;
    box-sizing: border-box;
  }
}
.flowcard_wrap .flow_num {
  position: absolute;
  width: 110px;
  bottom: -55px;
  left: 0;
  right: 0;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap .flow_num {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 80px;
    bottom: -30px;
  }
}
.flowcard_wrap .flowcard_img_wrap {
  position: relative;
}
.flowcard_wrap .flowcard_info_wrap {
  display: flex;
  flex-direction: column;
  padding: 80px 20px 40px 20px;
  text-align: center;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap .flowcard_info_wrap {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 40px 10px 30px 10px;
  }
}
.flowcard_wrap .flowcard_info_wrap .flowcard_title {
  text-align: center;
  font-size: 2.4rem;
  position: relative;
  margin-bottom: 45px;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap .flowcard_info_wrap .flowcard_title {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.1rem;
  }
}
.flowcard_wrap .flowcard_info_wrap .flowcard_title::before {
  content: "";
  display: block;
  position: absolute;
  background-color: #52cbd8;
  width: 100px;
  height: 3px;
  left: 0;
  right: 0;
  bottom: -13px;
  margin: auto;
}
@media only screen and (max-width: 630px) {
  .flowcard_wrap .flowcard_info_wrap .flowcard_title::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    bottom: -15px;
  }
}

.other_plan_wrap {
  margin-bottom: 40px;
}
.other_plan_wrap .other_plan_inner {
  display: grid;
  grid-template-columns: 2fr 1fr;
  border: 1px solid #52cbd8;
  padding: 10px 30px 0px 30px;
  border-radius: 30px 0px 0px 0px;
  position: relative;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_inner {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    grid-template-columns: 1fr;
  }
}
.other_plan_wrap .other_plan_left_wrap {
  padding-top: 20px;
}
.other_plan_wrap .other_plan_left_wrap .other_plan_ttl_wrap {
  padding-left: 10px;
  border-left: 3px solid #52cbd8;
}
.other_plan_wrap .other_plan_left_wrap .other_plan_ttl {
  font-size: 3rem;
  font-family: YakuHanJP_Narrow, "Noto Serif JP", serif;
  color: #4d4d4d;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_left_wrap .other_plan_ttl {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 2.4rem;
  }
}
.other_plan_wrap .other_plan_left_wrap .other_plan_ttl_en {
  font-size: 1.6rem;
  color: #52cbd8;
  font-family: YakuHanJP_Narrow, "NewYork", sans-serif;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_left_wrap .other_plan_ttl_en {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    font-size: 1.5rem;
  }
}
.other_plan_wrap .other_plan_left_wrap .other_plan_p {
  font-size: 1.4rem;
  color: #4d4d4d;
  font-weight: 300;
  margin-bottom: 15px;
}
.other_plan_wrap .other_plan_left_wrap .other_plan_benefit_img {
  max-width: 200px;
}
.other_plan_wrap .other_plan_bar {
  text-align: right;
  display: block;
  position: relative;
  padding-right: 20px;
  background-color: #52cbd8;
  padding: 10px 50px 10px 10px;
  text-align: right;
  color: #ffffff;
  font-size: 1.6rem;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_bar {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    padding: 10px 30px 10px 10px;
  }
}
.other_plan_wrap .other_plan_bar::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -10px;
  transform: translateY(-50%);
  width: 45px;
  height: 1px;
  background-color: #ffffff;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_bar::after {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 30px;
    right: -10px;
  }
}
.other_plan_wrap .other_plan_bar::before {
  content: "";
  position: absolute;
  top: 50%;
  right: -10px;
  transform: translateY(-50%);
  width: 45px;
  height: 1px;
  background-color: #ffffff;
  z-index: 2;
  animation: viewmore-scroll-horizontal 2s infinite;
}
@media only screen and (max-width: 630px) {
  .other_plan_wrap .other_plan_bar::before {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 30px;
    right: -10px;
  }
}

.other_plan_wrap.purchase .other_plan_inner {
  border: 1px solid #fb92b6;
}
.other_plan_wrap.purchase .other_plan_left_wrap .other_plan_ttl_wrap {
  border-left: 3px solid #fb92b6;
}
.other_plan_wrap.purchase .other_plan_left_wrap .other_plan_ttl_en {
  color: #fb92b6;
}
.other_plan_wrap.purchase .other_plan_bar {
  background-color: #fb92b6;
}

.other_plan_wrap.remake .other_plan_inner {
  border: 1px solid #8b92e4;
}
.other_plan_wrap.remake .other_plan_left_wrap .other_plan_ttl_wrap {
  border-left: 3px solid #8b92e4;
}
.other_plan_wrap.remake .other_plan_left_wrap .other_plan_ttl_en {
  color: #8b92e4;
}
.other_plan_wrap.remake .other_plan_bar {
  background-color: #8b92e4;
}

.other_plan_wrap.photo .other_plan_inner {
  border: 1px solid #81d29b;
}
.other_plan_wrap.photo .other_plan_left_wrap .other_plan_ttl_wrap {
  border-left: 3px solid #81d29b;
}
.other_plan_wrap.photo .other_plan_left_wrap .other_plan_ttl_en {
  color: #81d29b;
}
.other_plan_wrap.photo .other_plan_bar {
  background-color: #81d29b;
}

.ban {
  display: block;
}

/* アニメーション */
.animation-slide {
  clip-path: inset(0 100% 0 0);
}

.slideIn {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s;
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-animation-name: slideIn;
  animation-name: slideIn;
  visibility: visible !important;
  transition-timing-function: ease;
}

@-webkit-keyframes slideIn {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0.36;
    transform: scale(1.1);
  }
  100% {
    clip-path: inset(0);
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes slideIn {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0.3;
    transform: scale(1.1);
  }
  100% {
    clip-path: inset(0);
    opacity: 1;
    transform: scale(1);
  }
}
.fadeIn {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 2s;
  -ms-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  visibility: visible !important;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fadeInLeft {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.25s;
  -ms-animation-duration: 1.25s;
  animation-duration: 1.25s;
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
  visibility: visible !important;
}

@-webkit-keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
  }
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
.fadeInRight {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.25s;
  -ms-animation-duration: 1.25s;
  animation-duration: 1.25s;
  animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  -ms-animation-timing-function: ease;
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
  visibility: visible !important;
}

@-webkit-keyframes fadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
  }
}
@keyframes fadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-40px);
    -ms-transform: translateX(-40px);
    transform: translateX(-30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
.fadeInTop {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.25s;
  -ms-animation-duration: 1.25s;
  animation-duration: 1.25s;
  animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  -ms-animation-timing-function: ease;
  -webkit-animation-name: fadeInTop;
  animation-name: fadeInTop;
  visibility: visible !important;
}

@-webkit-keyframes fadeInTop {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
  }
}
@keyframes fadeInTop {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-30px);
    -ms-transform: translateY(-30px);
    transform: translateY(-30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
.fadeInBottom {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.25s;
  -ms-animation-duration: 1.25s;
  animation-duration: 1.25s;
  animation-timing-function: ease;
  -webkit-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  -ms-animation-timing-function: ease;
  -webkit-animation-name: fadeInBottom;
  animation-name: fadeInBottom;
  visibility: visible !important;
}

@-webkit-keyframes fadeInBottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
  }
}
@keyframes fadeInBottom {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    -ms-transform: translateY(30px);
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
.animationBar {
  display: inline-block;
  position: relative;
  overflow: hidden;
}

.animationBar span {
  animation: 0s fadeIn 0.5s ease forwards;
  opacity: 0;
  visibility: visible !important;
}

.animationBar:before {
  content: "";
  width: 0%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: rgb(0, 0, 0);
  visibility: visible !important;
  animation: 1.25s animationBar 0s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}

@keyframes animationBar {
  0% {
    width: 0%;
  }
  40% {
    width: 100%;
  }
  60% {
    width: 100%;
  }
  100% {
    width: 0%;
  }
}
.animationBar-wh {
  display: inline-block;
  position: relative;
  overflow: hidden;
}

.animationBar-wh span {
  animation: 0s fadeIn 0.5s ease forwards;
  opacity: 0;
  visibility: visible !important;
}

.animationBar-wh:before {
  content: "";
  width: 0%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background-color: rgb(255, 255, 255);
  visibility: visible !important;
  animation: 1.25s animationBar-wh 0s cubic-bezier(0.83, 0, 0.17, 1) forwards;
}

@keyframes animationBar-wh {
  0% {
    width: 0%;
  }
  40% {
    width: 100%;
  }
  60% {
    width: 100%;
  }
  100% {
    width: 0%;
  }
}
.fadeInScale {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1s;
  -ms-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-name: fadeInScale;
  animation-name: fadeInScale;
  visibility: visible !important;
  z-index: 1;
}

@keyframes fadeInScale {
  0% {
    opacity: 0;
    transform: scale(1.2);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.animation-grad-left {
  overflow: hidden;
  position: relative;
  visibility: visible !important;
}

.animation-grad-left:before {
  background: #000;
  bottom: 0;
  content: "";
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  opacity: 0.9;
}

.fadeInGradLeft:before {
  animation: fadeInGradLeft 0.8s cubic-bezier(0.87, 0, 0.13, 1) forwards;
}

@keyframes fadeInGradLeft {
  100% {
    transform: translateX(100%);
  }
}
.animation-grad-right {
  overflow: hidden;
  position: relative;
  visibility: visible !important;
}

.animation-grad-right:before {
  background: #000;
  content: "";
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
  opacity: 0.9;
}

.fadeInGradRight:before {
  animation: fadeInGradRight 0.8s cubic-bezier(0.87, 0, 0.13, 1) forwards;
}

@keyframes fadeInGradRight {
  100% {
    transform: translateX(-100%);
  }
}
.fadeInSlant {
  animation: fadeInSlant 2s ease forwards;
  animation-delay: 0.3s;
  transform-origin: 50% 0% 0px;
  transform: matrix3d(0.996195, 0, 0.0871557, -0.000217889, 0.00759612, 0.996195, -0.0868241, 0.00021706, -0.0868241, 0.0871557, 0.992404, -0.00248101, 0, 90, 0, 1);
  opacity: 0;
  visibility: visible !important;
}

@-webkit-keyframes fadeInSlant {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }
}
@keyframes fadeInSlant {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
  }
}
.loading_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  background-color: #ffffff;
  z-index: 999;
}

.loading {
  width: 60px; /* サイズ調整 */
  height: 60px;
  animation: spin 2s linear infinite;
  margin-bottom: 50px;
}
@media only screen and (max-width: 630px) {
  .loading {
    /*　画面サイズ $spWidth まではここを読み込む　*/
    width: 30px; /* サイズ調整 */
    height: 30px;
  }
}

@keyframes spin {
  0% {
    transform: scale(0.3) rotate(0deg);
  }
  0% {
    transform: scale(1.3);
  }
  100% {
    transform: scale(0.5) rotate(360deg);
  }
}