@charset "UTF-8";

/*all----------------------------*/
html {
  font-size: 62.5%;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
html::-webkit-scrollbar {
  display:none;
}
body {
  -webkit-tap-highlight-color: transparent;
}

main {
  max-width: none;
}

footer {
  position: relative;
  z-index: 10;
  margin-top: 0 !important;
}

.LP_page * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 1;
}

.LP_page {
  background: #F8F2EE;
  font-family: 'Lato', "ryo-gothic-plusn", sans-serif;
  font-feature-settings: "palt";
  color: #1f1f1f;
  --font-mix: 'Lato', "ryo-gothic-plusn", sans-serif;
}

.LP_page picture,
.LP_page a {
  display: block;
}

.LP_page a {
  transition: opacity .3s;
  color: inherit;
}

.LP_page a:hover {
  opacity: .6;
}

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

.LP_page .scrl_act {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s, transform 1s;
}
.LP_page .scrl_act.active {
  opacity: 1;
  transform: translateY(0);
}

/*----------------------------all*/

/*mv-----------------------------*/
.mv_area {
  display: block;
  position: relative;
}

.mv_area .mv {
  width: 100%;
  margin: 0 auto;
}

.main_ttl_wrap {
  width: auto;
}

.main_ttl {
  font-size: 1.7rem;
  font-weight: 400;
  letter-spacing: 0.125em;
  text-align: center;
  color: #E5826C;
  -webkit-text-stroke: 0.5px #E5826C;
  line-height: 2;
}

.mv_area .main_ttl {
  font-family: var(--font-mix);
  position: absolute;
  z-index: 10;
  top: 33.6rem;
  width: 100%;
  color: #D8615B;
  -webkit-text-stroke: 0.5px #D8615B;
}

.main_ttl_wrap p {
  font-size: 1.4rem;
  line-height: 2;
  letter-spacing: .125em;
  text-align: center;
  position: absolute;
  width: 100%;
  z-index: 10;
  top: 37.8rem;
}
/*-----------------------------mv*/

/*kit01----------------------------*/
#kit {
  background-image: url(../img/bg_sp02.jpg);
  background-repeat: no-repeat;
  background-position: center;
  /* background-size: cover; */
}
.kit_area01 {
  padding: 11rem 0 0;
}

.kit_area01 .sec_inner {
  position: relative;
}

.kit_area01 .kit_img_wrap {
  position: relative;
  border-radius: 100%;
  max-width: 41.5rem;
  height: 41.5rem;
  width: 100%;
  margin: 0 auto 2.9rem;
  padding: 11.5rem 0 0;
  background: rgba(255, 255, 255, .5);
  text-align: center;
}

.kit_area01 .kit_img_wrap .sec_ttl {
  position: absolute;
  top: 0;
  left: 0;
  max-width: 13.3rem;
  width: 100%;
  margin: 4.2rem 0 0 4.2rem;
}

.kit_area01 .kit_img {
  max-width: 45.1rem;
  width: 100%;
  position: absolute;
  top: 8rem;
  left: 0;
  z-index: 10;
}

.kit_area01 .kit_name {
  margin: 12.6rem auto 0.6rem;
  font-weight: 400;
  font-size: 2.15rem;
  letter-spacing: .125em;
  text-align: center;
  color: #E5826C;
  line-height: 2;
}

.kit_area01 .kit_price {
  font-size: 1.5rem;
  letter-spacing: .125em;
  text-align: center;
}

.kit_area01 .kit-content_list {
  margin-bottom: 3rem;
}

.kit_area01 .kit-content_list li {
  line-height: 1.85;
  letter-spacing: .07em;
  text-align: center;
}

.kit_area01 .kit-content_list li sup {
  font-size: 1rem;
  color: #91626c;
}

.kit_notes {
  font-size: 1rem;
  letter-spacing: .125em;
  text-align: center;
  color: #e48484;
  line-height: 2;
}
.kit_area01 .kit_notes {
  font-size: 1.15rem;
  letter-spacing: .125em;
  text-align: center;
  color: #E5826C;
  line-height: 2;
  margin-top: 2.2rem;
}
/*----------------------------kit01*/

/*kit02----------------------------*/
.kit_area02 {
  padding: 10.3rem 0 7.4rem;
}

.kit_area02 .sec_inner {
  position: relative;
}

.kit_area02 .kit_img_wrap {
  position: relative;
  border-radius: 100%;
  max-width: 41.5rem;
  height: 41.5rem;
  width: 100%;
  margin: 0 auto 2.9rem;
  padding: 11.5rem 0 0;
  background: rgba(255, 255, 255, .5);
  text-align: center;
}

.kit_area02 .kit_img_wrap .sec_ttl {
  position: absolute;
  top: 0;
  left: 0;
  max-width: 13.3rem;
  width: 100%;
  margin: 4.2rem 0 0 4.2rem;
}

.kit_area02 .kit_img {
  max-width: 45.1rem;
  width: 100%;
  position: absolute;
  top: 8.1rem;
  left: 0;
  z-index: 10;
}

.kit_area02 .kit_name {
  margin: 12.6rem auto 0.6rem;
  font-weight: 400;
  font-size: 2.15rem;
  letter-spacing: .125em;
  text-align: center;
  color: #F49492;
  line-height: 2;
}

.kit_area02 .kit_price {
  font-size: 1.5rem;
  letter-spacing: .125em;
  text-align: center;
}

.kit_area02 .kit-content_list {
  margin-bottom: 3rem;
}

.kit_area02 .kit-content_list li {
  line-height: 1.85;
  letter-spacing: .07em;
  text-align: center;
}

.kit_area02 .kit-content_list li sup {
  font-size: 1rem;
  color: #91626c;
}

.kit_area02 .kit_notes {
  font-size: 1.15rem;
  letter-spacing: .125em;
  text-align: center;
  color: #6E6E6E;
  line-height: 2;
  margin-top: 2.2rem;
}
/*----------------------------kit02*/

/*venue--------------------------*/
.venue_area {
  padding: 4.7rem 0 8rem;
  background-image: url(../img/bg_sp04.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.venue_area .sec_inner {
  max-width: 37rem;
  width: 100%;
  margin: 0 auto;
}

.venue_area .txt_wrap {
  /* margin-top: 6rem; */
}

.venue_area .sec_ttl {
  font-weight: 400;
  font-size: 3.45rem;
  letter-spacing: .075em;
  color: #E5826C;
}

.venue-floor {
  margin-bottom: 1.7rem;
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: .125em;
  color: #1F1F1F;
  margin-top: 2.3rem;
}

.venue-address {
  /* margin-bottom: 1.3rem; */
  font-size: 1.4rem;
  letter-spacing: .1em;
  line-height: 2;
}

.venue-tel {
  display: flex;
  gap: .4rem;
  font-size: 1.3rem;
  letter-spacing: .1em;
}

.venue-map {
  position: relative;
  border-radius: 1rem;
  max-width: 37rem;
  height: 15.3rem;
  width: 100%;
  background: #fff;
  box-shadow: 0 0 10px rgba(145, 98, 108, .2);
  overflow: hidden;
  margin-top: 2.6rem;
}

.venue-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/*--------------------------venue*/

.LP_page .notes {
  font-size: 1.15rem;
  letter-spacing: .125em;
  text-align: center;
  color: #6E6E6E;
}


#item01 {
  /* background: linear-gradient(-45deg, #f5e8e4 0%, #fdecea 30%, #f5e8e4 65%, #fdecea 100%); */
  background-image: url(../img/bg_sp01.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.item-area01 {
    padding: 7.5rem 0 7.3rem;
}

.item-area01 .txt-intro {
  font-size: 1.4rem;
  letter-spacing: 0.125em;
  text-align: center;
  line-height: 2;
}

.item-area01 .item-cont {
  background: rgba(255, 255, 255, 0.5);
  border-radius: 2rem;
  max-width: 72rem;
  width: 92.5%;
  margin: 8.8rem auto 3.7rem;
  padding: 5.7rem 0 3.6rem;
  text-align: center;
  position: relative;
}

.item-area01 .item-cont .ico {
  background: #EA9081;
  max-height: 10.4rem;
  max-width: 10.4rem;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  padding-top: 4.2rem;
  color: #fff;
  font-size: 1.8rem;
  letter-spacing: .125em;
  position: absolute;
  top: -5.2rem;
  right: -0.5rem;
}


#item01 .item-img {
  max-width: 28rem;
  width: 100%;
}

.item-area01 .item-cont h3 {
  font-weight: 400;
  font-size: 2.2rem;
  letter-spacing: .125em;
  color: #E5826C;
  margin: 3.3rem auto 2.7rem;
}

.item-area01 .item-cont h3 span {
  font-size: 1.3rem;
  display: block;
  padding-top: 1.9rem;
}

.item-area01 .item-cont .item-price {
  font-size: 1.5rem;
  letter-spacing: .125em;
}

.item-area01  .txt-detail {
  font-size: 1.85rem;
  line-height: 2;
  text-align: center;
  letter-spacing: .125em;
}

.item-area01 .txt-detail .notes {
  padding-top: 1.7rem;
  display: block;
  line-height: 2.34;
}

  .kit_area01 .kit_img_wrap .ico {
  max-width: 19rem;
  width: 100%;
  position: absolute;
  top: -1rem;
  right: 1.5rem;
}
.kit_area02 .kit_img_wrap .ico {
  max-width: 18.1rem;
  width: 100%;
  position: absolute;
  top: -0.9rem;
  left: 2.6rem;
}

.sec_inner .kit_list {
  line-height: 2;
  font-size: 1.38rem;
  letter-spacing: .125em;
  text-align: center;
}

#freeservice h3 {
    font-size: 2.8rem;
    text-align: center;
    color: #e48484;
    font-weight: 400;
    margin-bottom: 4.5rem;
    letter-spacing: .1em;
}

#freeservice {
    background: #f8f2ee;
}

#freeservice .item-cont {
    padding: 5rem 0;
    margin-bottom: 0;
}

#freeservice .item-img {
    max-width: 32rem;
    width: 100%;
}

.venue-floor span {
  color: #1f1f1f;
  font-size: 1.4rem;
  display: block;
  padding-bottom: 2.7rem;
  letter-spacing: .125em;
}

#item02 {
  /* background: linear-gradient(-45deg, #f5e8e4 0%, #fdecea 30%, #f5e8e4 65%, #fdecea 100%); */
  background-image: url(../img/bg_sp03.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.item-area02 {
    padding: 7.5rem 0 7.3rem;
}

.item-area02 .txt-intro {
  font-size: 1.4rem;
  letter-spacing: 0.125em;
  text-align: center;
  line-height: 2;
}

.item-area02 .item-cont {
  background: rgba(255, 255, 255, 0.5);
  border-radius: 2rem;
  max-width: 72rem;
  width: 92.5%;
  margin: 3.5rem auto 0.5rem;
  padding: 3rem 0 7.2rem;
  text-align: center;
  position: relative;
}

.item-area02 .item-cont .ico {
  max-width: 28.5rem;
  width: 100%;
  position: absolute;
  top: -2.2rem;
  left: 7rem;
}


#item02 .item-img {
  max-width: 22rem;
  width: 100%;
}

.item-area02 .item-cont h3 {
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: .075em;
  color: #FCBBBB;
  margin: 0 auto 3rem;
}

.item-area02 .item-cont h3 span {
  font-size: 1.3rem;
  display: block;
  padding-top: 1.9rem;
}

.item-area02 .item-cont .item-price {
  font-size: 1.4rem;
  letter-spacing: .125em;
  line-height: 2;
  margin-top: 3.4rem;
}

.item-area02  .txt-detail {
  font-size: 1.8rem;
  line-height: 2;
  text-align: center;
  letter-spacing: .125em;
}

.item-area02 .txt-detail .notes {
  padding-top: 2.2rem;
  display: block;
  line-height: 2.34;
}

  .kit_area01 .kit_img_wrap .ico {
    max-width: 19rem;
    width: 100%;
    position: absolute;
    top: -1rem;
    right: 1.5rem;
}
.kit_area02 .kit_img_wrap .ico {
  max-width: 18.1rem;
  width: 100%;
  position: absolute;
  top: -0.9rem;
  left: 2.6rem;
}

#item02 .inner02{
  padding: 3.8rem 0;
}

.inner02 .item-cont {
  background: rgba(255, 255, 255, 0.5);
  border-radius: 2rem;
  max-width: 72rem;
  width: 92.5%;
  margin: 3.5rem auto 0.5rem;
  padding: 4.6rem 0 7.2rem;
  text-align: center;
  position: relative;
}

.inner02 .item-cont h3 {
  font-weight: 400;
  font-size: 3.1rem;
  letter-spacing: .075em;
  color: #D8BF9C;
  margin: 0 auto 3rem;
  line-height: 1.5;
}
#item02 .inner02 .item-img {
  max-width: 21.4rem;
  width: 100%;
  margin-left: 1.1rem;
}
.inner02 .item-cont .item-price {
  margin-top: 3.3rem;
}
.inner02 .item-cont .item-price:nth-of-type(2) {
  margin-top: 2.5rem;
}
/*sp---------------------------*/
@media screen and  (max-width:768px) {
  .only_pc {
    display: none;
  }
}
/*---------------------------sp*/

/*PC------------------------------------------------------*/
@media screen and  (min-width:769px) {
  .only_sp {
    display: none;
  }

  .LP_page {
    position: relative;
    z-index: 1;
  }

  .LP_page_inner {
    position: relative;
    z-index: 1;
    margin: 0 auto;
  }

  .LP_page_inner,
  .modal_outside,
  .fixedNavigation {
    width: 39.4rem;
    overflow: clip;
  }

  .page_content {
    display: flex;
    justify-items: center;
  }
  
  .LP_page_inner {
    max-width: calc(394*(100vw / 1400));
    margin: auto;
  }

  .fixed_left,
  .fixed_right {
    display: grid;
    width: calc((100% - 39.4rem) / 2);
    /* max-width: calc((168rem - 39.4rem) / 2); */
  }

  .fixed_left{
    background-image: url(../img/bg_pc01.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: sticky;
    height: 100vh;
    top: 0;
  }
  .fixed_right{
    background-image: url(../img/bg_pc02.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: sticky;
    height: 100vh;
    top: 0;
  }

  .fixed_left_top {
    position: absolute;
    width: 100%;
    height: auto;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  .fixed_left .main_ttl {
    font-family: var(--font_eng);
    font-size: 2rem;
    text-align: center;
  }

  .fixed_left .main_ttl span {
    display: block;
    width: 35rem;
    margin: 0 auto 1rem;
  }

  .fixed_left .sub_ttl {
    font-family: var(--font_serif);
    font-size: 1.3rem;
    letter-spacing: .125em;
    line-height: 2;
    text-align: center;
    margin-top: 2.6rem;
  }

  .fixed_left .sub_ttl .txt_S {
    display: block;
    margin-top: 1rem;
    font-size: 1.3rem;
  }

  .fixed_right .fixed_right_nav {
    position: absolute;
    padding: 0 0 0 28%;
    height: auto;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
  }

  .fixed_right .PCnavigation_list ul {
    width: 25rem;
  }

  .fixed_right .PCnavigation_list > li:nth-of-type(n+2) {
    margin-top: 4.7rem;
  }

  .fixed_right .PCnavigation_list > li {
    width: fit-content;
    font-size: 1.3rem;
  }

  .fixed_right .PCnavigation_list > li .txt_eng {
    display: block;
    margin-bottom: 1.9rem;
    font-family: var(--font_eng);
    font-size: 2.4rem;
    font-weight: 400;
    letter-spacing: .075em;
    color: #E5826C;
  }

  .fixed_right .PCproduct_list {
    margin-top: 2.8rem;
  }

  .fixed_right .PCproduct_list li:nth-of-type(n+2) {
    margin-top: 2rem;
  }

  .fixed_right .PCproduct_list li a {
    width: fit-content;
    position: relative;
    padding-left: 2rem;
    font-family: var(--font_eng);
    font-size: 1.3rem;
    letter-spacing: .1em;
    color: #E5826C;
  }

  .fixed_right .PCproduct_list li a::before {
    position: absolute;
    top: 50%;
    left: -0.4rem;
    translate: 0 -50%;
    width: 0.8rem;
    height: 0.8rem;
    border-top: solid 1px #E5826C;
    border-right: solid 1px #E5826C;
    transform: rotate(45deg);
    content: "";
  }

  .fixed_right .PCproduct_list li a.logo {
    width: 10rem;
  }

  .mv_area .main_ttl {
    top: 29.4rem;
    font-size: 1.5rem;
  }
  .main_ttl_wrap p {
    font-size: 1.2rem;
    top: 33.1rem;
  }

  .item-area01 {
    padding: 6.6rem 0 6.5rem;
  }

  .item-area01 .txt-intro {
    font-size: 1.2rem;
  }

  .item-area01 .item-cont {
    margin: 7.8rem auto 3.4rem;
    padding: 5rem 0 3.2rem;
  }

  .item-area01 .item-cont .ico {
    max-height: 9.1rem;
    max-width: 9.1rem;
    padding-top: 3.5rem;
    top: -4.6rem;
    right: -0.5rem;
  }
  #item01 .item-img {
    max-width: 24.3rem;
  }
  .item-area01 .item-cont h3 {
    font-size: 1.9rem;
    margin: 3.1rem auto 2.3rem;
  }
  .item-area01 .item-cont h3 span {
    font-size: 1.2rem;
    padding-top: 1.5rem;
  }
  .item-area01 .item-cont .item-price {
    font-size: 1.3rem;
  }
  .item-area01 .txt-detail {
    font-size: 1.6rem;
  }
  .item-area01 .txt-detail .notes {
    padding-top: 1.7rem;
    font-size: 1rem;
  }
  .kit_area01 {
    padding: 9.5rem 0 0;
  }
  .kit_area01 .kit_img_wrap {
    height: 36.5rem;
    width: 93%;
    margin: 0 auto 2.3rem;
    padding: 8.2rem 0 0;
  }
  .kit_area01 .kit_img_wrap .ico {
    max-width: 16.9rem;
    top: -1rem;
    right: 1.4rem;
  }
  .kit_area01 .kit_img {
    top: 7rem;
  }
  .kit_area01 .kit_name {
    margin: 12.9rem auto 0.4rem;
    font-size: 1.9rem;
  }
  .kit_area01 .kit_price {
    font-size: 1.3rem;
  }
  .sec_inner .kit_list {
    font-size: 1.2rem;
  }
  .kit_area01 .kit_notes {
    font-size: 1rem;
    margin-top: 2rem;
  }
  .kit_area02 {
    padding: 9.1rem 0 6.5rem;
  }
  .kit_area02 .kit_img {
    top: 7.1rem;
  }
  .kit_area02 .kit_img_wrap .ico {
    max-width: 16rem;
    top: -0.9rem;
    left: 2.4rem;
  }
  .kit_area02 .kit_img_wrap {
    height: 36.4rem;
    width: 93%;
    margin: 0 auto 2.5rem;
    padding: 9rem 0 0;
  }
  .kit_area02 .kit_name {
    margin: 12.1rem auto 0.3rem;
    font-size: 1.9rem;
  }
  .kit_area02 .kit_price {
    font-size: 1.3rem;
  }
  .kit_area02 .kit_notes {
    font-size: 1rem;
    margin-top: 2rem;
  }
  .item-area02 {
    padding: 6.1rem 0 2.8rem;
  }
  .item-area02 .item-cont {
    margin: 3.5rem auto 0.5rem;
    padding: 2.7rem 0 6.4rem;
  }
  .item-area02 .item-cont .ico {
    max-width: 25rem;
    top: -2rem;
    left: 6rem;
  }
  .item-area02 .item-cont h3 {
    font-size: 1.7rem;
    margin: 0 auto 2.6rem;
  }
  #item02 .item-img {
    max-width: 19.2rem;
  }
  .item-area02 .item-cont .item-price {
    font-size: 1.2rem;
    margin-top: 3rem;
  }
  .item-area02 .txt-detail .notes {
    padding-top: 1.9rem;
    font-size: 1rem;
  }
  .inner02 .item-cont {
    margin: 2.5rem auto 0.5rem;
    padding: 4.2rem 0 6.4rem;
  }
  .inner02 .item-cont h3 {
    font-size: 2.7rem;
    margin: 0 auto 2.6rem;
  }
  #item02 .inner02 .item-img {
    max-width: 18.7rem;
    margin-left: 1rem;
  }
  .venue_area {
    padding: 7rem 0 5rem;
  }
  .venue_area .sec_inner {
    max-width: 32.5rem;
  }
  .venue_area .sec_ttl {
    font-size: 3rem;
    margin-left: 0.2rem;
  }
  .venue-floor {
    margin-bottom: 1.6rem;
    font-size: 1.6rem;
    margin-top: 2.1rem;
    padding-left: 0.1rem;
  }
  .venue-floor span {
    font-size: 1.2rem;
    padding-bottom: 2.2rem;
  }
  .venue-address {
    font-size: 1.2rem;
    padding-left: 0.1rem;
  }
}
/*------------------------------------------------------PC*/

/*レスポンシブ対応-------------------------------*/
@media screen and (max-width: 1400px) and (min-width: 769px) {
  html {
    font-size: calc(10 * (100vw / 1400));
  }
}

@media screen and (max-width: 768px) {
  html {
    font-size: calc(10 * (100vw / 450));
  }
  #FooterWrap {
    margin-top: -6rem;
  }
}
/*-------------------------------レスポンシブ＆タブレット対応*/