@charset "UTF-8";
/*=======================================
                  PC   
========================================*/
/* fonts */
/* fonts-size */
/* color */
/*=======================================
 	        animation
 ========================================*/
.inview {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  opacity: 0;
}

.inview.active {
  opacity: 1;
}

#wrapper .description {
  position: relative;
}

#wrapper .description p {
  font-size: 1.4rem;
  line-height: 2;
  color: #333333;
}

#wrapper .img {
  background-color: #fff;
}

#wrapper .cont2 {
  position: relative;
}

#wrapper .cont2::before {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: initial;
}

#wrapper .title {
  z-index: 2;
}

#wrapper .title p {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  position: relative;
  color: #333333;
}

#wrapper .title h2 {
  font-family: kudryashev-d-contrast, sans-serif;
  font-size: 4.8rem;
  letter-spacing: 0.05em;
  color: #df6c7e;
}

/* ===================
	　 firstview
=================== */
#firstview {
  text-align: center;
  position: relative;
  width: 106rem;
  margin: 0 auto 16.6rem;
}

#firstview a {
  display: block;
}

#firstview .fv-img {
  width: 106rem;
  position: relative;
  margin: 0 auto 8.3rem;
}

#firstview p {
  font-size: 1.4rem;
  line-height: 2;
  color: #333333;
}

#firstview .title {
  margin-top: 8.9rem;
  margin-bottom: 2.4rem;
}

#firstview .title h3 {
  font-family: kudryashev-d-contrast, sans-serif;
  font-size: 3.6rem;
  letter-spacing: 0.075em;
  color: #df6c7e;
  margin-bottom: 0.3rem;
}

#firstview .title p {
  font-family: dnp-shuei-mincho-pr6, sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.035em;
}

#firstview .scene {
  font-size: 1.6rem;
  letter-spacing: 0.025em;
  margin-bottom: 10.6rem;
}

#firstview .scene li {
  position: relative;
  margin-bottom: 2.1rem;
  color: #333333;
}

#firstview .scene li span {
  width: 1rem;
  height: 1rem;
  display: inline-block;
  margin-bottom: 0.1rem;
  margin-right: 1rem;
}

#firstview .scene li:nth-child(1) span {
  background-color: #e58998;
  margin-right: 1.1rem;
}

#firstview .scene li:nth-child(2) span {
  background-color: #eca7b2;
}

#firstview .scene li:nth-child(3) span {
  background-color: #f2c4cb;
}

#firstview .scene li:nth-child(4) span {
  background-color: #f7dadf;
}

#firstview .advice {
  position: relative;
}

#firstview .advice h4 {
  position: absolute;
  font-family: kudryashev-d-contrast, sans-serif;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  -webkit-transform: rotate(3deg);
          transform: rotate(3deg);
  right: 15rem;
  top: -3.7rem;
  color: #333333;
}

#firstview .advice::before {
  content: "";
  position: absolute;
  width: 72.6rem;
  height: 21.6rem;
  background-image: url("../img/bg01.png");
  background-repeat: no-repeat;
  background-size: contain;
  left: 16.9rem;
  top: -3.4rem;
  z-index: -1;
}

#firstview .advice p {
  position: relative;
  color: #333333;
}

#firstview .advice .quotation {
  position: relative;
}

#firstview .advice .quotation::before {
  content: "";
  position: absolute;
  width: 2.3rem;
  height: 2.2rem;
  background-image: url("../img/quotation_left.svg");
  background-repeat: no-repeat;
  background-size: initial;
  left: 23rem;
  top: -4.4rem;
}

#firstview .advice .quotation::after {
  content: "";
  position: absolute;
  width: 2.3rem;
  height: 2.1rem;
  background-image: url("../img/quotation_right.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: 23rem;
  bottom: -4.7rem;
}

/* ===================
	　 section01
=================== */
.sec01 {
  margin-bottom: 15rem;
}

.sec01 .cont1 {
  margin-left: 25.5rem;
}

.sec01 .cont1 .left .img-all {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-bottom: 5.3rem;
}

.sec01 .cont1 .left .img-all .img01 {
  width: 40rem;
}

.sec01 .cont1 .left .img-all .title {
  position: relative;
  margin-top: 12rem;
  margin-left: -2.7rem;
}

.sec01 .cont1 .left .img-all .title::before {
  content: "";
  position: absolute;
  width: 11rem;
  height: 18rem;
  background-image: url("../img/number01.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -9rem;
  top: 6rem;
}

.sec01 .cont1 .left .img-all .title p {
  position: relative;
  margin-left: 24.4rem;
  margin-bottom: 1.9rem;
}

.sec01 .cont1 .left .img-all .title p::before {
  content: "";
  position: absolute;
  width: 4.9rem;
  height: 5.3rem;
  background-image: url("../img/arrow.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -3.1rem;
  top: 1rem;
}

.sec01 .cont1 .left .description {
  width: 40rem;
  text-align: justify;
}

.sec01 .cont1 .left .description .price {
  margin-top: 2.7rem;
}

.sec01 .cont1 .img02 {
  width: 40rem;
  margin-top: 31.9rem;
  margin-left: -40rem;
  text-align: right;
  z-index: 2;
}

.sec01 .cont1 .img02 p {
  position: relative;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  display: inline-block;
  color: #333333;
  padding-left: 2.9rem;
  padding-bottom: 3.4rem;
  margin-top: 3.6rem;
}

.sec01 .cont1 .img02 p::before {
  content: "";
  position: absolute;
  width: 2.4rem;
  height: 2.4rem;
  background-image: url("../img/washable.png");
  background-repeat: no-repeat;
  background-size: contain;
  left: 0;
  top: -0.6rem;
}

.sec01 .cont1 .img02 p::after {
  content: "";
  position: absolute;
  width: 17.4rem;
  height: 14.4rem;
  background-color: #fffdf3;
  left: -4rem;
  bottom: 0;
  z-index: -1;
}

/* ===================
	　 section02
=================== */
.sec02 {
  position: relative;
  padding-top: 49rem;
  margin-left: 15.5rem;
  padding-bottom: 52.9rem;
  margin-bottom: 18.8rem;
}

.sec02 .img01 {
  position: absolute;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  width: 100%;
  bottom: 0;
}

.sec02 .img01 img {
  width: 45rem;
}

.sec02 .img01 .price {
  margin-left: 2.1rem;
  margin-bottom: -0.5rem;
}

.sec02 .img02 {
  position: absolute;
  width: 51rem;
  top: 0;
  left: 29rem;
  z-index: 2;
  mix-blend-mode: multiply;
}

.sec02 .img03 {
  position: absolute;
  width: 44rem;
  top: 28rem;
  left: 71rem;
}

.sec02 .title {
  position: relative;
  margin-left: 15rem;
  margin-bottom: 2.8rem;
}

.sec02 .title p {
  position: relative;
  display: inline-block;
  margin-left: 16.5rem;
  margin-bottom: 1.9rem;
}

.sec02 .title p::before {
  content: "";
  position: absolute;
  width: 4.9rem;
  height: 5.3rem;
  background-image: url("../img/arrow.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -3.1rem;
  top: 1rem;
}

.sec02 .description {
  width: 47rem;
  text-align: justify;
  display: inline-block;
  margin-left: 15rem;
}

.sec02 .description::before {
  content: "";
  position: absolute;
  width: 14rem;
  height: 18rem;
  background-image: url("../img/number02.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -3rem;
  top: 6.7rem;
  z-index: -1;
}

/* ===================
	　 section03
=================== */
.sec03 .cont1 {
  margin-left: 21.2rem;
}

.sec03 .cont1 .img01 {
  width: 30rem;
  margin-top: 33rem;
}

.sec03 .cont1 .img01 .price {
  margin-top: 3.3rem;
}

.sec03 .cont1 .right {
  margin-left: 12rem;
  margin-bottom: 11.2rem;
}

.sec03 .cont1 .right .img02 {
  width: 36rem;
  margin-bottom: 9rem;
  margin-left: 19.6rem;
}

.sec03 .cont1 .right .title {
  margin-bottom: 2.5rem;
}

.sec03 .cont1 .right .title p {
  display: inline-block;
  position: relative;
  margin-left: 16rem;
  margin-bottom: 1.9rem;
}

.sec03 .cont1 .right .title p::before {
  content: "";
  position: absolute;
  width: 4.9rem;
  height: 5.3rem;
  background-image: url("../img/arrow.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -3.1rem;
  top: 1rem;
}

.sec03 .cont1 .right .description {
  text-align: justify;
  position: relative;
  width: 46.6rem;
}

.sec03 .cont1 .right .description::before {
  content: "";
  position: absolute;
  width: 14.2rem;
  height: 18rem;
  background-image: url("../img/number03.svg");
  background-repeat: no-repeat;
  background-size: initial;
  right: -9rem;
  top: 3.7rem;
  z-index: -1;
}

.sec03 .img03 {
  width: 40rem;
  margin-left: 69.8rem;
}

.sec03 .img03 ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.sec03 .img03 ul::after {
  content: "";
  position: absolute;
  width: 29.6rem;
  height: 14.4rem;
  background-color: #fffdf3;
  left: -4rem;
  bottom: 0;
  z-index: -1;
}

.sec03 .img03 ul li {
  position: relative;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.025em;
  display: inline-block;
  color: #333333;
  padding-left: 2.9rem;
  padding-bottom: 3.3rem;
  margin-top: 3.6rem;
}

.sec03 .img03 ul li:nth-child(1) {
  margin-right: 1.5rem;
}

.sec03 .img03 ul li:nth-child(1)::before {
  content: "";
  position: absolute;
  width: 2.4rem;
  height: 2.4rem;
  background-image: url("../img/washable.png");
  background-repeat: no-repeat;
  background-size: contain;
  left: 0;
  top: -0.6rem;
}

.sec03 .img03 ul li:nth-child(2)::before {
  content: "";
  position: absolute;
  width: 2.4rem;
  height: 2.4rem;
  background-image: url("../img/beforeafter.png");
  background-repeat: no-repeat;
  background-size: contain;
  left: 0;
  top: -0.6rem;
}

.sec03 .staff {
  text-align: center;
  font-family: "Crimson Text", serif;
  font-size: 1.3rem;
  line-height: 1.6923;
  letter-spacing: 0.015em;
  margin-top: 11.7rem;
  color: #333333;
}

/* for SP */
@media screen and (max-width: 767px) {
  #wrapper .description {
    position: relative;
  }
  #wrapper .description p {
    font-size: calc(26* (100vw / 750));
  }
  #wrapper .title {
    z-index: 1;
  }
  #wrapper .title p {
    font-size: calc(30* (100vw / 750));
    letter-spacing: 0.05em;
    position: relative;
  }
  #wrapper .title h2 {
    font-size: calc(66* (100vw / 750));
  }
  #wrapper .img {
    background-color: transparent;
  }
  /* ===================
	　 firstview
=================== */
  #firstview {
    width: 100%;
    margin: 0 auto calc(232* (100vw / 750));
  }
  #firstview .fv-img {
    width: 100%;
    margin: 0 auto calc(107* (100vw / 750));
  }
  #firstview p {
    font-size: calc(26* (100vw / 750));
  }
  #firstview .title {
    margin-top: calc(117* (100vw / 750));
    margin-bottom: calc(50* (100vw / 750));
  }
  #firstview .title h3 {
    font-size: calc(56* (100vw / 750));
    margin-bottom: calc(10* (100vw / 750));
  }
  #firstview .title p {
    font-size: calc(26* (100vw / 750));
    letter-spacing: 0.035em;
  }
  #firstview .scene {
    font-size: calc(30* (100vw / 750));
    margin-bottom: calc(210* (100vw / 750));
  }
  #firstview .scene li {
    margin-bottom: calc(36* (100vw / 750));
  }
  #firstview .scene li span {
    width: calc(16* (100vw / 750));
    height: calc(16* (100vw / 750));
    margin-bottom: calc(4* (100vw / 750));
    margin-right: calc(16* (100vw / 750));
  }
  #firstview .scene li:nth-child(1) span {
    margin-bottom: calc(2* (100vw / 750));
    margin-right: calc(15* (100vw / 750));
  }
  #firstview .scene li:nth-child(2) {
    margin-left: 0;
  }
  #firstview .advice h4 {
    font-size: calc(36* (100vw / 750));
    -webkit-transform: rotate(3deg);
            transform: rotate(3deg);
    right: calc(31* (100vw / 750));
    top: calc(-87* (100vw / 750));
  }
  #firstview .advice::before {
    width: calc(711* (100vw / 750));
    height: calc(467* (100vw / 750));
    background-image: url("../img/sp_bg01.png");
    left: 0;
    right: 0;
    top: calc(-79* (100vw / 750));
    margin: auto;
  }
  #firstview .advice .quotation::before {
    width: calc(36* (100vw / 750));
    height: calc(33* (100vw / 750));
    left: calc(60* (100vw / 750));
    top: calc(-94* (100vw / 750));
  }
  #firstview .advice .quotation::after {
    width: calc(36* (100vw / 750));
    height: calc(33* (100vw / 750));
    right: calc(69* (100vw / 750));
    /* bottom: calc(-83* (100vw / 750)); */
    bottom: auto;
    top: calc(362* (100vw / 750));
  }
  /* ===================
	　 section01
=================== */
  .sec01 {
    margin-bottom: calc(180* (100vw / 750));
  }
  .sec01 .cont1 {
    margin-left: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .sec01 .cont1 .left .img-all {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    margin-bottom: calc(48* (100vw / 750));
  }
  .sec01 .cont1 .left .img-all .img01 {
    width: calc(560* (100vw / 750));
    margin-left: calc(50* (100vw / 750));
    z-index: 2;
  }
  .sec01 .cont1 .left .img-all .title {
    margin-top: 0;
    margin-left: calc(63* (100vw / 750));
    margin-bottom: calc(48* (100vw / 750));
  }
  .sec01 .cont1 .left .img-all .title::before {
    width: calc(165* (100vw / 750));
    height: calc(270* (100vw / 750));
    right: auto;
    left: calc(522* (100vw / 750));
    top: calc(120* (100vw / 750));
    z-index: -1;
  }
  .sec01 .cont1 .left .img-all .title h2 {
    line-height: 1.0606;
  }
  .sec01 .cont1 .left .img-all .title h2 span:nth-child(2) {
    padding-left: calc(363* (100vw / 750));
  }
  .sec01 .cont1 .left .img-all .title p {
    margin-left: calc(85* (100vw / 750));
    margin-bottom: calc(23* (100vw / 750));
  }
  .sec01 .cont1 .left .img-all .title p::before {
    width: calc(73* (100vw / 750));
    height: calc(83* (100vw / 750));
    background-image: url("../img/sp_arrow.svg");
    right: auto;
    left: calc(479* (100vw / 750));
    top: calc(14* (100vw / 750));
  }
  .sec01 .cont1 .left .description {
    width: calc(560* (100vw / 750));
    margin-left: calc(50* (100vw / 750));
  }
  .sec01 .cont1 .left .description .price {
    margin-top: calc(16* (100vw / 750));
  }
  .sec01 .cont1 .img02 {
    width: calc(560* (100vw / 750));
    margin-top: calc(50* (100vw / 750));
    margin-left: calc(140* (100vw / 750));
    text-align: left;
  }
  .sec01 .cont1 .img02 p {
    font-size: calc(26* (100vw / 750));
    padding-left: calc(54* (100vw / 750));
    padding-bottom: calc(47* (100vw / 750));
    margin-top: calc(52* (100vw / 750));
  }
  .sec01 .cont1 .img02 p::before {
    width: calc(44* (100vw / 750));
    height: calc(44* (100vw / 750));
    left: 0;
    top: calc(-12* (100vw / 750));
  }
  .sec01 .cont1 .img02 p::after {
    width: calc(254* (100vw / 750));
    height: calc(204* (100vw / 750));
    left: calc(-40* (100vw / 750));
    bottom: 0;
  }
  /* ===================
	　 section02
=================== */
  .sec02 {
    padding-top: 0;
    margin-left: 0;
    padding-bottom: 0;
    margin-bottom: calc(171* (100vw / 750));
  }
  .sec02 .img01 {
    position: relative;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    width: calc(570* (100vw / 750));
    bottom: 0;
    margin-bottom: calc(20* (100vw / 750));
  }
  .sec02 .img01 img {
    width: calc(570* (100vw / 750));
  }
  .sec02 .img01 .price {
    margin-left: 2.1rem;
    margin-bottom: -0.5rem;
  }
  .sec02 .img02 {
    position: relative;
    width: calc(570* (100vw / 750));
    top: 0;
    left: 0;
    mix-blend-mode: initial;
    margin-bottom: calc(60* (100vw / 750));
  }
  .sec02 .img03 {
    position: relative;
    width: calc(640* (100vw / 750));
    top: 0;
    left: 0;
    margin-left: calc(80* (100vw / 750));
  }
  .sec02 .img03 .price {
    margin-left: calc(3* (100vw / 750));
    margin-top: calc(27* (100vw / 750));
  }
  .sec02 .title {
    position: relative;
    margin-left: calc(76* (100vw / 750));
    margin-bottom: calc(39* (100vw / 750));
  }
  .sec02 .title p {
    position: relative;
    display: inline-block;
    margin-left: calc(90* (100vw / 750));
    margin-bottom: calc(25* (100vw / 750));
  }
  .sec02 .title p::before {
    width: calc(73* (100vw / 750));
    height: calc(83* (100vw / 750));
    background-image: url("../img/sp_arrow.svg");
    right: auto;
    left: calc(482* (100vw / 750));
    top: calc(14* (100vw / 750));
  }
  .sec02 .description {
    width: calc(640* (100vw / 750));
    margin-left: calc(80* (100vw / 750));
    margin-bottom: calc(50* (100vw / 750));
  }
  .sec02 .description::before {
    width: calc(210* (100vw / 750));
    height: calc(270* (100vw / 750));
    right: calc(-50* (100vw / 750));
    top: calc(-341* (100vw / 750));
  }
  /* ===================
	　 section03
=================== */
  .sec03 .cont1 {
    margin-left: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .sec03 .cont1 .img01 {
    width: calc(450* (100vw / 750));
    margin-top: 0;
    margin-left: auto;
    margin-bottom: calc(60* (100vw / 750));
  }
  .sec03 .cont1 .img01 .price {
    margin-top: 3.3rem;
  }
  .sec03 .cont1 .right {
    margin-left: 0;
    margin-bottom: calc(50* (100vw / 750));
  }
  .sec03 .cont1 .right .title {
    margin-bottom: calc(39* (100vw / 750));
    margin-left: calc(30* (100vw / 750));
  }
  .sec03 .cont1 .right .title p {
    display: inline-block;
    position: relative;
    margin-left: calc(84* (100vw / 750));
    margin-bottom: calc(25* (100vw / 750));
  }
  .sec03 .cont1 .right .title p::before {
    width: calc(73* (100vw / 750));
    height: calc(83* (100vw / 750));
    background-image: url("../img/sp_arrow.svg");
    right: auto;
    left: calc(484* (100vw / 750));
    top: calc(14* (100vw / 750));
  }
  .sec03 .cont1 .right .description {
    width: calc(640* (100vw / 750));
    margin-left: calc(30* (100vw / 750));
  }
  .sec03 .cont1 .right .description::before {
    width: calc(213* (100vw / 750));
    height: calc(270* (100vw / 750));
    right: calc(-80* (100vw / 750));
    top: calc(263* (100vw / 750));
  }
  .sec03 .cont1 .right .description .price {
    margin-top: calc(17* (100vw / 750));
  }
  .sec03 .cont1 .img02 {
    width: calc(540* (100vw / 750));
    margin-bottom: calc(30* (100vw / 750));
    margin-left: calc(30* (100vw / 750));
  }
  .sec03 .img03 {
    width: calc(540* (100vw / 750));
    margin-left: calc(180* (100vw / 750));
  }
  .sec03 .img03 ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .sec03 .img03 ul::after {
    width: calc(468* (100vw / 750));
    height: calc(204* (100vw / 750));
    left: calc(-41* (100vw / 750));
    bottom: 0;
  }
  .sec03 .img03 ul li {
    font-size: calc(26* (100vw / 750));
    padding-left: calc(54* (100vw / 750));
    padding-bottom: calc(47* (100vw / 750));
    margin-top: calc(52* (100vw / 750));
  }
  .sec03 .img03 ul li:nth-child(1) {
    margin-right: calc(15* (100vw / 750));
  }
  .sec03 .img03 ul li:nth-child(1)::before {
    width: calc(44* (100vw / 750));
    height: calc(44* (100vw / 750));
    left: 0;
    top: calc(-11* (100vw / 750));
  }
  .sec03 .img03 ul li:nth-child(2)::before {
    width: calc(44* (100vw / 750));
    height: calc(44* (100vw / 750));
    left: 0;
    top: calc(-11* (100vw / 750));
  }
  .sec03 .staff {
    margin-top: calc(170* (100vw / 750));
    font-size: calc(23* (100vw / 750));
    line-height: 1.73913;
  }
}
/*# sourceMappingURL=style.css.map */