@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
.txtEx {
  text-indent: 120%;
  white-space: nowrap;
  overflow: hidden;
}

.SP {
  display: none !important;
}

:root {
  --font-default: "Noto Sans JP", "sans-serif";
  --font-Mincho: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

:where(html) {
  scroll-behavior: smooth;
  scroll-padding-top: 0rem;
  /*overflow: overlay;*/
  font-size: 62.5%; /*1rem = 10px*/
  font-size: 0.90909vw; /*defaultFontsize / maxWidth * 100*/
  /*max-width: 750px;*/ /*maxWidth*/
  margin: 0 auto;
}

@media screen and (min-width: 1100px) {
  :where(html) {
    font-size: 10px; /*defaultFontsize*/
  }
}
:where(body) {
  font-family: var(--font-default);
  width: 100%;
  margin: 0 auto;
  /*overflow-x: hidden;*/
}

:where(img) {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

:where(picture) {
  display: inline-block;
  vertical-align: bottom;
}

a:where([class]) {
  display: inline-block;
  transition: opacity 0.12s;
}

a:where([class]):hover {
  opacity: 0.8;
}

*[class] > mark {
  color: inherit;
  background: none;
}

body {
  position: relative;
}

body.is-modalopen:before {
  content: "";
  position: fixed;
  z-index: 999;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
}

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

._img .__bg {
  width: 200rem;
  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: 7rem;
  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: 9.5rem;
}

.hd01__menu .btn {
  cursor: pointer;
  position: relative;
  z-index: 100;
  width: 7rem;
  height: 7rem;
  background: url("../img/h01__btn-on.png") no-repeat center center;
  background-size: 100% 100%;
}

.hd01__menu.is-open .btn {
  background-image: url("../img/h01__btn-off.png");
}

.hd01__menu .btn:hover {
  opacity: 0.8;
}

.hd01__menu .menuwrap {
  position: absolute;
  z-index: 1;
  top: 0rem;
  right: 0;
  transform: scaleX(0);
  transform-origin: right center;
  width: 32rem;
  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: 7rem;
  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: 74rem;
  margin-top: 7rem;
  background: url("../img/fv_bg.jpg") no-repeat center top;
  background-size: 200rem;
}

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

.fv__wrap .fv__t01 {
  position: absolute;
  z-index: 10;
  right: 3rem;
  bottom: 17rem;
  width: 35.5rem;
}

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

.campaign {
  min-height: 87.6rem;
  background: url("../img/campaign_bg.jpg") no-repeat center top 4.6rem;
  background-size: 200rem;
}

.campaign__t02 {
  width: 58.6rem;
  margin: 0 auto;
  margin-bottom: 4rem;
  padding-top: 7.6rem;
}

.campaign__t03 {
  width: 107.2rem;
  margin: 0 auto;
  margin-bottom: 2rem;
}

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

.prob {
  min-height: 97rem;
  padding-top: 8.8rem;
  background: url("../img/prob_bg.jpg") no-repeat center top;
  background-size: 200rem;
}

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

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

.at {
  position: relative;
  z-index: 10;
  min-height: 134.2rem;
  margin-top: -17.4rem;
  padding-top: 18.4rem;
  background: url("../img/at_bg.png") no-repeat center top;
  background-size: 200rem;
}

.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: 19.8rem;
  margin-bottom: 34rem;
  margin-left: 11rem;
}

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

.point {
  margin-top: -16.8rem;
  padding-top: 18.8rem;
  background: url("../img/point__p01_bg.png") no-repeat center top;
  background-size: 200rem;
}

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

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

.point1__t01 {
  width: 50.4rem;
  margin: 0 1.4rem 0 auto;
  margin-bottom: 37rem;
}

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

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

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

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

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

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

.point2__t01 {
  width: 50.4rem;
  margin: 0 auto 0 0;
  margin-bottom: 50rem;
}

.point2__t02 {
  width: 114rem;
  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: 13.7rem;
  margin-bottom: 5rem;
}

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

.studio {
  position: relative;
  z-index: 10;
  height: 81rem;
  padding-top: 12.8rem;
  background: url("../img/studio_bg.png") no-repeat center top;
  background-size: 200rem;
}

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

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

.plan {
  height: 180rem;
  margin-top: -5rem;
  padding-top: 7rem;
  background: url("../img/plan_bg.jpg") no-repeat center top;
  background-size: 200rem;
}

.plan__t01 {
  width: 36.4rem;
  margin: 0 auto;
  margin-bottom: -3rem;
}

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

.plan__t02lists {
  display: flex;
  justify-content: center;
  gap: 0 2rem;
}

.plan__t02lists li {
  width: 33rem;
  margin-top: 1rem;
  margin-bottom: 3rem;
}

.plan__t02listtxt {
  width: 34.7rem;
  margin: 0 auto;
  margin-bottom: 8rem;
}

.plan__t03list {
  width: 40rem;
  margin: 0 auto;
  margin-top: 3rem;
}

.faq {
  padding-top: 7rem;
  padding-bottom: 10rem;
  background: #f5f5eb no-repeat center top;
  background-image: url("../img/faq_bg.png");
  background-size: 200rem;
}

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

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

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

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

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

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

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

.faq__lists li .content {
  display: none;
}

.line {
  min-height: 60rem;
  padding-top: 9rem;
  padding-bottom: 5rem;
  background: url("../img/line_bg.jpg") no-repeat center top;
  background-size: 200rem;
}

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

.line__t01 {
  width: 62rem;
  margin-left: 3rem;
  margin-bottom: 3.5rem;
}

.line__btn {
  display: block;
  width: 55.1rem;
  margin-bottom: 4rem;
  margin-left: 3rem;
}

.line__scroll {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  height: 27.5rem;
  border: 0.2rem solid #ccc;
  border-radius: 1.5rem;
  overflow: hidden;
}

.line__scrollwrap {
  height: 100%;
  padding: 3rem 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: 100.4rem;
  margin: 0 auto;
  margin-bottom: 1rem;
  font-size: 2.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

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

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

.line__scrollwrap .t01 {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0;
  width: 100.4rem;
  margin: 0 auto;
  margin-bottom: 2rem;
  font-size: 1.8rem;
  font-weight: 300;
  line-height: 1.66;
  letter-spacing: 0.06em;
}

.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.toku {
  display: inline-block;
  width: 20rem;
  min-width: 0;
}

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

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

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

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

.access__txt .t02 {
  margin-bottom: 4.5rem;
  color: #fff;
  font-size: 1.8rem;
  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: 96rem;
  height: 54rem;
  margin: 0 auto;
}

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

.ft01 {
  background: url("../img/pc_bg_copy.jpg") no-repeat top center;
  padding-top: 3rem;
}
@media screen and (max-width: 1100px) {
  .ft01 {
    background-size: 200rem auto;
  }
}
.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: 1.6rem;
  padding-right: 1rem;
}
.ft01 .foot_nav li:first-child::before {
  content: none;
}
.ft01 .foot_nav li a {
  color: #1A1A1A;
  font-size: 1.6rem;
  text-decoration: none;
}
.ft01 .foot_nav li a:hover {
  opacity: 0.8;
}/*# sourceMappingURL=common.css.map */