.txtEx {
  text-indent: 120%;
  white-space: nowrap;
  overflow: hidden;
}

.PC {
  display: none !important;
}

.SP {
  display: inherit !important;
}

html {
  font-size: 1.30208vw; /*defaultFontsize(10px) / maxWidth(750px) * 100*/
}

body {
  margin-bottom: 24.4rem;
}

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

/*--------------------
No1*/
/*--No2*/
/*No3*/
.float_area {
  width: 100%;
  padding-top: 3rem;
  background: rgba(255, 255, 255, 0.85);
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99;
}

._img {
  display: flex;
  justify-content: center;
  overflow: hidden;
}

._img .__bg {
  width: 100%;
  max-width: none;
}

.hd01 {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1000;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 9rem;
  margin: 0 auto;
  background: #fff;
}

.hd01__wrap {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}

.hd01__logo {
  width: 14.2rem;
  margin-left: 4rem;
}

.hd01__menu .btn {
  cursor: pointer;
  position: relative;
  z-index: 100;
  width: 9rem;
  height: 9rem;
}

.hd01__menu .menuwrap {
  position: absolute;
  z-index: 1;
  top: 0rem;
  right: 0;
  transform: scaleX(0);
  transform-origin: right center;
  width: 54rem;
  transition: transform 0.15s;
}

.hd01__menu.is-close .menuwrap {
  transition-delay: 0.25s;
}

.hd01__menu .menuwrap:before {
  content: "";
  position: relative;
  z-index: 10;
  display: block;
  height: 9rem;
  background: #c8b594;
}

.hd01__menu.is-open .menuwrap {
  transform: scaleX(1);
}

.hd01__menu .menuwrap .lists {
  position: absolute;
  z-index: -1;
  transform: translateY(-100%);
  background: #fff;
  transition: transform 0.15s;
  transition-delay: 0.25s;
}

.hd01__menu.is-open2 .menuwrap .lists {
  transform: translateY(0%);
}

.fv {
  position: relative;
  height: 112.1rem;
  margin-top: 9rem;
  background: url("../img/spfv_bg.jpg") no-repeat center top;
  background-size: 100%;
}

.fv__wrap {
  position: relative;
  width: 100%;
  height: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

.fv__wrap .fv__t01 {
  position: absolute;
  z-index: 10;
  right: 4rem;
  bottom: 12rem;
  width: 42.5rem;
}

.fv__wrap .fv__t02 {
  position: absolute;
  z-index: 10;
  top: 3rem;
  left: 3rem;
  width: 13.9rem;
}

.campaign {
  min-height: 127.8rem;
  background: url("../img/spcampaign_bg.jpg") no-repeat center top 7.8rem;
  background-size: 100%;
}

.campaign__t02 {
  width: 68.1rem;
  margin: 0 auto;
  margin-bottom: 0rem;
  padding-top: 11.6rem;
}

.campaign__t03 {
  width: 73rem;
  margin: 0 auto;
  margin-bottom: 3rem;
}

.campaign__btn {
  display: block;
  width: 66.2rem;
  margin: 0 auto;
}

.prob {
  min-height: 127.2rem;
  padding-top: 8.8rem;
  background: url("../img/spprob_bg.jpg") no-repeat center top;
  background-size: 100%;
}

.prob__t01 {
  width: 66.8rem;
  margin: 0 auto;
  margin-bottom: 4.6rem;
}

.prob__t02 {
  width: 73.8rem;
  margin: 0 auto;
}

.at {
  position: relative;
  z-index: 10;
  min-height: 135.4rem;
  margin-top: -11rem;
  padding-top: 18.4rem;
  background: url("../img/spat_bg.png") no-repeat center top;
  background-size: 100%;
}

.at__wrap {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}

.at__t01 {
  width: 65.4rem;
  margin: 0 auto;
  margin-bottom: 3.6rem;
}

.at__t02 {
  width: 21rem;
  margin-bottom: 26rem;
  margin-left: 4rem;
}

.at_btn {
  display: block;
  width: 66.2rem;
  margin: 0 auto;
}

.point {
  margin-top: -12.8rem;
  padding-top: 16.8rem;
  background: url("../img/sppoint__p01_bg.png") no-repeat center top;
  background-size: 100%;
}

.point__t01 {
  width: 57rem;
  margin: 0 auto;
}

.point1__wrap {
  max-width: 1160px;
  width: 100%;
  margin: 0 auto;
  padding-top: 93rem;
  overflow: hidden;
}

.point1__t01 {
  width: 61rem;
  margin: 0 auto;
  margin-bottom: 0rem;
}

.point1__wrap .lists {
  display: flex;
  justify-content: center;
  gap: 0 6.2rem;
  margin-bottom: 8rem;
}

.point1__wrap .lists li {
  width: 30rem;
}

.point1__t02 {
  width: 66.8rem;
  margin: 0 auto;
  margin-bottom: -15rem;
}

.point1__t03 {
  width: 100%;
  margin: 0 auto;
  margin-bottom: 4rem;
}

.point2__wrap {
  max-width: 2000px;
  width: 100%;
  margin: 0 auto;
  background: url("../img/sppoint__p02_bg.png") no-repeat center top;
  background-size: 100%;
  overflow: hidden;
}

.point2__area {
  max-width: 1160px;
  width: 100%;
  margin: 0 auto;
}

.point2__t01 {
  width: 61.3rem;
  margin: 0 auto;
  margin-top: 54rem;
  margin-bottom: 16rem;
}

.point2__t02 {
  width: auto;
  margin: 0 auto;
  margin-bottom: 0rem;
}

.point3__wrap {
  max-width: 2000px;
  width: 100%;
  margin: 0 auto;
}

.point3__area {
  max-width: 1140px;
  width: 100%;
  margin: 0 auto;
}

.point3__bg {
  margin-top: 6rem;
  margin-bottom: 7rem;
}

.point3__t01 {
  width: 100%;
  margin: 0 auto;
  margin-bottom: 7rem;
}

.point__listsslide {
  margin-bottom: 13rem;
  background: url("../img/sppoint__p01_t01bg.jpg") no-repeat center center;
  background-size: 100% 100%;
}

.point__listsslide .slick-dots {
  display: flex;
  justify-content: center;
  gap: 0 6rem;
}

.point__listsslide .slick-dots li {
  width: auto;
  height: auto;
}

.point__listsslide .slick-dots li button {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: #ccc;
  overflow: hidden;
  text-indent: 120%;
  white-space: nowrap;
}

.point__listsslide .slick-dots li.slick-active button {
  background: #f09fc3;
}

.studio {
  position: relative;
  z-index: 10;
  height: 135rem;
  padding-top: 27rem;
  background: url("../img/spstudio_bg.png") no-repeat center top;
  background-size: 100%;
}

.studio__t01 {
  width: 76.8rem;
  margin: 0 auto;
  margin-bottom: 6rem;
}

.studio__btn {
  display: block;
  width: 66.2rem;
  margin: 0 auto;
}

.plan {
  min-height: 381rem;
  margin-top: -3.5rem;
  padding-top: 11rem;
  background: url("../img/spplan_bg.jpg") no-repeat center top;
  background-size: 100%;
}

.plan__t01 {
  width: 47.1rem;
  margin: 0 auto;
  margin-bottom: 2rem;
}

.plan__t01a {
  width: 100%;
  margin: 0 auto;
  margin-bottom: 2rem;
}

ul.plan__t02lists {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0rem 0rem;
  margin-top: 2rem;
}

.plan__t02lists li {
  width: 100%;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.plan__t02listtxt {
  width: 100%;
  margin: 0 auto;
  margin-top: 4rem;
  margin-bottom: 10rem;
}

.plan__t03list {
  width: 100%;
  margin: 0 auto;
  margin-top: 6rem;
}

.faq {
  padding-top: 11rem;
  padding-bottom: 10rem;
  background: #f5f5eb no-repeat center top;
  background-image: url("../img/spfaq_bg.png");
  background-size: 100%;
}

.faq__t01 {
  width: 50rem;
  margin: 0 auto;
  margin-bottom: 4.6rem;
}

ul.faq__lists {
  display: flex;
  flex-direction: column;
  gap: 4rem 0;
  width: 66.8rem;
  margin: 0 auto;
}

.faq__lists li .btn {
  cursor: pointer;
  display: flex;
  align-items: center;
  width: 100%;
  height: 12rem;
}

.faq__lists li .btn:hover {
  opacity: 0.8;
}

.faq__lists li .btn:before,
.faq__lists li .btn:after {
  content: "";
  display: block;
  width: 12rem;
  height: 12rem;
  background: no-repeat center center;
  background-size: 100%;
}

.faq__lists li .btn:after {
  border-radius: 0 3rem 0 0;
  margin: 0 0 0 auto;
  background-image: url("../img/faq__btn-on.png");
}

.faq__lists li.is-open .btn:after {
  background-image: url("../img/faq__btn-off.png");
}

.faq__lists li .content {
  display: none;
}

.line {
  min-height: 141.3rem;
  padding-top: 11rem;
  padding-bottom: 5rem;
  background: url("../img/spline_bg.jpg") no-repeat center top;
  background-size: 100%;
}

.line__wrap {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

.line__t01 {
  width: 68.2rem;
  margin: 0 auto;
  margin-bottom: 0.5rem;
}

.line__btn {
  display: block;
  width: 66.2rem;
  margin: 0 auto;
  margin-bottom: 71.7rem;
}

.line__scroll {
  width: 67rem;
  max-width: 1100px;
  margin: 0 auto;
  height: 37.5rem;
  border: 0.2rem solid #ccc;
  border-radius: 2rem;
  overflow: hidden;
}

.line__scrollwrap {
  height: 100%;
  padding: 4.5rem 0;
  overflow-y: scroll;
}

.line__scrollwrap::-webkit-scrollbar {
  width: 3rem;
}

.line__scrollwrap::-webkit-scrollbar-thumb {
  background-color: #695137;
  border-radius: 40em;
}

.line__scrollwrap::-webkit-scrollbar-track {
  background-color: #d9d9d9;
  border-radius: 40em;
}

.line__scrollwrap::-webkit-scrollbar-corner {
  display: none;
}

.line__scrollwrap .h01 {
  width: 54.5rem;
  margin: 0 auto;
  margin-bottom: 3rem;
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.line__scrollwrap * + .h01 {
  margin-top: 6rem;
}

.line__scrollwrap .h02 {
  width: 54.5rem;
  margin: 0 auto;
  margin-bottom: 1rem;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.line__scrollwrap .t01 {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0;
  width: 54.5rem;
  margin: 0 auto;
  margin-bottom: 4rem;
  font-size: 2.4rem;
  font-weight: 300;
  line-height: 1.83;
  letter-spacing: 0.06em;
}

.line__scrollwrap .t01.ls002 {
  letter-spacing: 0.02em;
}

.line__scrollwrap .t01.ls010 {
  letter-spacing: 0.1em;
}

.line__scrollwrap .t01.ls014 {
  letter-spacing: 0.14em;
}

.line__scrollwrap .t01 span {
  display: inline-block;
  min-width: 2.4em;
}

.line__scrollwrap .t01 span.auto {
  display: inline-block;
  width: calc(100% - 2.4em);
  min-width: 0;
}

.line__scrollwrap .t01 span.auto.ls001 {
  letter-spacing: 0.01em;
}

.line__scrollwrap .t01 span.auto.ls002 {
  letter-spacing: 0.02em;
}

.line__scrollwrap .t01 span.auto.ls004 {
  letter-spacing: 0.04em;
}

.line__scrollwrap .t01 span.auto.ls005 {
  letter-spacing: 0.05em;
}

.line__scrollwrap .t01 span.auto.ls011 {
  letter-spacing: 0.11em;
}

.line__scrollwrap .t01 span.auto.nowrap {
  white-space: nowrap;
}

.line__scrollwrap .t01 span.toku {
  display: inline-block;
  width: 20rem;
  min-width: 0;
}

.line__scrollwrap .t01 span.auto2 {
  display: inline-block;
  width: calc(100% - 20rem);
  min-width: 0;
}

.line__scrollwrap .t01 span.auto2.nowrap {
  white-space: nowrap;
}

.access {
  min-height: 108.5rem;
  padding-top: 10rem;
  padding-bottom: 0rem;
  background: url("../img/access_bg.jpg") no-repeat center top;
  background-size: 200rem;
  overflow: hidden;
}

.access__t01 {
  width: 33.6rem;
  margin: 0 auto;
  margin-bottom: 2.5rem;
}

.access__txt .t01 {
  margin-bottom: 2rem;
  color: #fff;
  font-size: 2.8rem;
  text-align: center;
  line-height: 1.78;
  letter-spacing: 0.14em;
}

.access__txt .t02 {
  margin-bottom: 7.5rem;
  color: #fff;
  font-size: 2.6rem;
  text-align: center;
  line-height: 1.88;
  letter-spacing: 0.14em;
}

.access__txt .t02 mark {
  margin-right: 1rem;
  padding: 0.3em 1em;
  background: none;
  border: 1px solid #fff;
  border-radius: 10em;
}

.access__map {
  width: 66.8rem;
  height: 37.5rem;
  margin: 0 auto;
}

.access__map iframe {
  width: 100%;
  height: 100%;
}

.ft01 {
  background: url("../img/sp_bg_copy.jpg") no-repeat top center/100%;
}
.ft01 .foot_nav {
  display: flex;
  justify-content: center;
}
.ft01 .foot_nav li {
  padding-left: 1rem;
}
.ft01 .foot_nav li::before {
  content: "|";
  color: #333;
  font-size: 2.2rem;
  padding-right: 1.5rem;
}
.ft01 .foot_nav li:first-child::before {
  content: none;
}
.ft01 .foot_nav li a {
  color: #1A1A1A;
  font-size: 2.2rem;
  text-decoration: none;
}/*# sourceMappingURL=common_sp.css.map */