@charset "UTF-8";

.content h1, .content h2, .content h3, .content h4, .content h5, .content h6, .content p, .content blockquote, .content pre, .content a, .content abbr, .content acronym, .content address, .content big, .content cite, .content code, .content del, .content dfn, .content em, .content img, .content ins, .content kbd, .content q, .content s, .content samp, .content small, .content strike, .content strong, .content sub, .content sup, .content tt, .content var, .content b, .content u, .content i, .content center, .content dl, .content dt, .content dd, .content ol, .content ul, .content li{
  line-height: 0;
  font-size: 0;
}
section{
  position: relative;
  text-align: center;
}



.content img{
  display: block;
  margin:0 auto;
  width: 100%;
  line-height: 0;
  height: auto;
  vertical-align: bottom;
}

.content .p-box{
  position: relative;
}


#Wrap{
  max-width: 750px;
  width:100%;
  margin: 0 auto;
  overflow-x: hidden;
}

/* cv */

#Wrap .content .cv{
  position: relative;
}

#Wrap .content .btn_cv{
  position: absolute;
  width: calc(641/750*100%);
  top: 84.6%;
  left:50%;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  transition: filter ease 0.3s;
  transition:width ease 0.3s;
  cursor: pointer;
}

#Wrap .content .btn_cv:hover{
/* opacity:0.8; */
  filter: drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.2));
  width: calc(690/750*100%);
}

#Wrap .content .benefits{
  padding: 3.7% calc(38/750*100%) 9.5%;
  background: #faeff2;
}

#Wrap .content .benefits .benefits_ttl{
  width: calc(636/674*100%);
  margin: 0 auto 6%;
}

#Wrap .content .benefits .benefits_list li{
  margin-bottom: 2%;
  opacity: 0;
}

/* fv */

#Wrap .content .fv{
  position: relative;
}

#Wrap .content .fv_copy01{
  position: absolute;
  top: 16.24%;
  left: 84%;
  width: calc(81/750*100%);
}

#Wrap .content .fv_copy01 p:nth-child(1){
  width: 100%;
  opacity: 0;
}

#Wrap .content .fv_copy01 p:nth-child(2){
  position: absolute;
  width: calc(58/81*100%);
  top: 2.8%;
  left: 9.3%;
  opacity: 0;
}

#Wrap .content .fv_copy02{
  position: absolute;
  top: 43.2%;
  left: 71%;
  width: calc(81/750*100%);
}

#Wrap .content .fv_copy02 p:nth-child(1){
  width: 100%;
  opacity: 0;
}

#Wrap .content .fv_copy02 p:nth-child(2){
  position: absolute;
  width: calc(50/81*100%);
  top: 7.4%;
  left: 21%;
  opacity: 0;
}

#Wrap .content .fv_banner {
  position: relative;
}

#Wrap .content .btn_fv_banner {
  position: absolute;
  width: calc(467/750*100%);
  top: 69%;
  left: 32.5%;
}

/* intro */

#Wrap .content .intro {
  position: relative;
}

#Wrap .content .intro_copy {
  position: absolute;
  width: calc(108/750*100%);
  top: 8%;
  left: 74%;
  opacity: 0;
}

#Wrap .content .intro_box {
  position: absolute;
  width: calc(461/750*100%);
  height: min(calc(617/750*100vw),617px);
  top: 4%;
  left: 0;
  overflow: hidden;
}

#Wrap .content .intro_texture {
  position: absolute;
  width: calc(277/750*100%);
  top: 33%;
  left: 37%;
}

#Wrap .content .intro_txt {
  position: absolute;
  width: calc(550/750*100%);
  top: 55.7%;
  left: 15%;
  opacity: 0;
}

/* problem */

#Wrap .content .problem_ttl {
  position: absolute;
  width: calc(634/750*100%);
  top: 15.8%;
  left: 8%;
  opacity: 0;
}

#Wrap .content .problem_component li:nth-child(1){
  width: calc(231/750*100%);
  position: absolute;
  top: 63.5%;
  left: 19.5%;
  opacity: 0;
}

#Wrap .content .problem_component li:nth-child(2){
  width: calc(231/750*100%);
  position: absolute;
  top: 63.5%;
  left: 50.4%;
  opacity: 0;
}

#Wrap .content .problem_txt{
  width: calc(275/750*100%);
  position: absolute;
  top: 32.5%;
  left: 31.4%;
  opacity: 0;
}

#Wrap .content .problem_figure{
  width: calc(540/750*100%);
  position: absolute;
  top: 0;
  left: 14%;
  opacity: 0;
}

#Wrap .content .turnover_ttl{
  width: calc(671/750*100%);
  position: absolute;
  top: 29.4%;
  left: 5%;
  opacity: 0;
}

#Wrap .content .turnover_figure li:nth-child(1){
  width: calc(509/750*100%);
  position: absolute;
  top: calc(177/750*100%);
  left: 0;
  opacity: 0;
}

#Wrap .content .turnover_figure li:nth-child(2){
  width: calc(423/750*100%);
  position: absolute;
  top: calc(351/750*100%);
  right: 0;
  opacity: 0;
  z-index: 2;
}

#Wrap .content .figure-front{
  position: relative;
  z-index: 3;
  margin-top: 0.5%;
}

#Wrap .content .whitening_point{
  position: relative;
  background: #fbd5db;
}

#Wrap .content .whitening_point li:nth-child(1){
  padding-top: 7.2%;
  width: calc(709/750*100%);
  margin-right: auto;
  opacity: 0;
}

#Wrap .content .whitening_point li:nth-child(2){
  width: calc(709/750*100%);
  margin-left: auto;
  margin-top: 7.3%;
  opacity: 0;
}

#Wrap .content .whitening_point li:nth-child(3){
  padding-top: 7%;
  width: calc(709/750*100%);
  margin-right: auto;
  opacity: 0;
}

/* technology */

#Wrap .content .product{
  background: #e9edf0;
}

#Wrap .content .product_head{
  position: relative;
  overflow: visible;
}

#Wrap .content .product_ttl{
  width: calc(595/750*100%);
  position: absolute;
  top: 9%;
  left: 9.5%;
  z-index: 10;
}

#Wrap .content .product_img{
  width: calc(643/750*100%);
  margin: 0 auto 0 9%;
}

#Wrap .content .simpleParallax{
  overflow: visible !important;
}

#Wrap .content .simpleParallax img{
  overflow: visible !important;
  width: calc(643/750*100%);
}

#Wrap .content .sticky_area{
  z-index: 5;
  position: relative;
  margin-top: -69%;
  padding-bottom: 15%;
}


#Wrap .content .product_icon li:nth-child(1){
  width: calc(195/750*100%);
  position: absolute;
  top: 0;
  left: 9.3%;
  z-index: 10;
  opacity: 0;
}

#Wrap .content .product_icon li:nth-child(2){
  width: calc(195/750*100%);
  position: absolute;
  top: 0;
  left: 37%;
  z-index: 10;
  opacity: 0;
}

#Wrap .content .product_icon li:nth-child(3){
  width: calc(195/750*100%);
  position: absolute;
  top: 0;
  left: 65%;
  z-index: 10;
  opacity: 0;
}

#Wrap .content .product_icon li:nth-child(4){
  width: calc(195/750*100%);
  position: absolute;
  top: 19.5%;
  left: 23.3%;
  z-index: 10;
  opacity: 0;
}

#Wrap .content .product_icon li:nth-child(5){
  width: calc(195/750*100%);
  position: absolute;
  top: 19.5%;
  left: 51%;
  z-index: 10;
  opacity: 0;
}

/* story */

#Wrap .content .story{
  padding-bottom: 8%;
}

#Wrap .content .story_slider .slide{
  margin: 0 7%;
}

#Wrap .content .story_slider .arrow_prev {
	width: calc(23/750*100%);
	position: absolute;
	top: 52%;
	left: 3%;
	transform: translateY(-50%);
	z-index: 10;
  cursor: pointer;
}
#Wrap .content .story_slider .arrow_next {
	width: calc(23/750*100%);
	position: absolute;
	top: 52%;
	right: 3%;
	transform: translateY(-50%);
	z-index: 10;
  cursor: pointer;
}

/* voice */

#Wrap .content .voice_list{
  position: relative;
  background: #ffecf0;
}

#Wrap .content .voice_list li:nth-child(1){
  width: calc(670/750*100%);
  margin: 0 auto;
  opacity: 0;
}

#Wrap .content .voice_list li:nth-child(2){
  padding-top: 3.4%;
  width: calc(670/750*100%);
  margin: 0 auto;
  opacity: 0;
}

#Wrap .content .voice_list li:nth-child(3){
  padding-top: 4%;
  width: calc(670/750*100%);
  margin: 0 auto;
  opacity: 0;
}

#Wrap .content .voice_list li:nth-child(4){
  padding-top: 4.2%;
  width: calc(670/750*100%);
  margin: 0 auto;
  opacity: 0;
}

/* faq */

#Wrap .content .faq{
  background-color: #fff;
  padding-bottom: 5%;
}

#Wrap .content .faq .accordion{
  width: 100%;
  margin: 0 auto 3.4%;
  border: 1.25px solid #000;
}

#Wrap .content .faq .inner{
  width: calc(668/750*100%);
  margin: 0 auto;
}

#Wrap .content .faq .accordion dt{
  cursor: pointer;
  position: relative;
}

#Wrap .content .faq .accordion dt:before{
  content: "";
  display: block;
  background-image: url('/ud/default/img/lp/y/3030/images/arrow_acc.png');
  background-size: contain;
  transform: rotate(0deg);
  width: min(calc(24/750*100vw),24px);
  padding-top: min(calc(13/750*100vw),13px);
  position: absolute;
  top: 50%;
  right: 5%;
  transition: all ease 0.3s;
}

#Wrap .content .faq .accordion dt.selected:before{
  transform: rotate(180deg);
}

#Wrap .content .faq .accordion dd{
  display: none;
}
.turnover-attention {
text-align: left;
padding: 30px 30px 0;
font-family: "IwaGGoPro-Md";
font-size: 14px;
}

#Wrap #fixdBtn{
  position: fixed;
  bottom: 0;
  left: 0;
  transition: all ease 0.3s;
  width: 100%;
  opacity: 1;
  z-index: 10;
}

#Wrap #fixdBtn .fixed_inner{
  max-width: 750px;
  margin: 0 auto;
}

#Wrap #fixdBtn .fv_offer{
  width: 92%;
  margin: 0 auto 1%;
}
#Wrap #fixdBtn.is-bnrHide{
  opacity: 0;
  pointer-events: none;
}

/* -----------------------------------------
  アニメーション
----------------------------------------- */
/* アニメーション共通 */
.io {
  transition: all 0.5s ease-in;
}

/* fade-in
-------------------- */
.io_fade_in {
  opacity: 0;
  transition: all 0.5s ease-in;
}

#Wrap .content .io_fade_in.is-active {
  opacity: 1 !important;
}

/* img-wrap 
-------------------- */
.io_img_wrap.is-active {
  -webkit-animation: img-wrap 1.0s cubic-bezier(0.860, 0.000, 0.070, 1.000) both;
  animation: img-wrap 1.0s cubic-bezier(0.860, 0.000, 0.070, 1.000) both;
}

@-webkit-keyframes img-wrap {
  0% {
    clip-path: inset(0 0 100% 0);
    -webkit-clip-path: inset(0 0 100% 0);
  }

  5% {
    opacity: 1;
  }

  100% {
    clip-path: inset(0 0 0 0);
    -webkit-clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}

@keyframes img-wrap {
  0% {
    clip-path: inset(0 0 100% 0);
    -webkit-clip-path: inset(0 0 100% 0);
  }

  5% {
    opacity: 1;
  }

  100% {
    clip-path: inset(0 0 0 0);
    -webkit-clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}


/* fade-in-bottom 
-------------------- */
.fade-in-bottom.is-active {
  -webkit-animation: fade-in-bottom 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
  animation: fade-in-bottom 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
}

@-webkit-keyframes fade-in-bottom {
  0% {
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}

@keyframes fade-in-bottom {
  0% {
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}


/* fade-in-right 
-------------------- */
.fade-in-right.is-active {
  -webkit-animation: fade-in-right 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
  animation: fade-in-right 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
}

@-webkit-keyframes fade-in-right {
  0% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

@keyframes fade-in-right {
  0% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}


/* fade-in-left 
-------------------- */
.fade-in-left.is-active {
  -webkit-animation: fade-in-left 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
  animation: fade-in-left 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
}

@-webkit-keyframes fade-in-left {
  0% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

@keyframes fade-in-left {
  0% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}



/* slide-in-tl 
-------------------- */
.io_slide_in_tl.is-active {
  -webkit-animation: slide-in-tl 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
  animation: slide-in-tl 0.5s cubic-bezier(0.645, 0.045, 0.355, 1.000) both;
}

@-webkit-keyframes slide-in-tl {
  0% {
    -webkit-transform: translateY(-1000px) translateX(-1000px);
    transform: translateY(-1000px) translateX(-1000px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0) translateX(0);
    transform: translateY(0) translateX(0);
    opacity: 1;
  }
}

@keyframes slide-in-tl {
  0% {
    -webkit-transform: translateY(-1000px) translateX(-1000px);
    transform: translateY(-1000px) translateX(-1000px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0) translateX(0);
    transform: translateY(0) translateX(0);
    opacity: 1;
  }
}

/* slide-in-tl 
-------------------- */
.io_slide_in_tr.is-active {
  -webkit-animation: slide-in-tr 0.5s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
  animation: slide-in-tr 0.5s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
}

@-webkit-keyframes slide-in-tr {
  0% {
    -webkit-transform: translateY(-1000px) translateX(1000px);
    transform: translateY(-1000px) translateX(1000px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0) translateX(0);
    transform: translateY(0) translateX(0);
    opacity: 1;
  }
}

@keyframes slide-in-tr {
  0% {
    -webkit-transform: translateY(-1000px) translateX(1000px);
    transform: translateY(-1000px) translateX(1000px);
    opacity: 0;
  }

  100% {
    -webkit-transform: translateY(0) translateX(0);
    transform: translateY(0) translateX(0);
    opacity: 1;
  }
}

/* scale-down-center 
-------------------- */
.io_scale-down-center.is-active {
  -webkit-animation: scale-down-center 1.8s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
  animation: scale-down-center 1.8s cubic-bezier(0.215, 0.610, 0.355, 1.000) both;
}

@-webkit-keyframes scale-down-center {
  0% {
    -webkit-transform: scale(1.5) rotate(10deg);
            transform: scale(1.5) rotate(10deg);
            opacity: 0;
  }

  100% {
    -webkit-transform: scale(1) rotate(0deg);
            transform: scale(1) rotate(0deg);
    opacity: 1;
  }
}

@keyframes scale-down-center {
  0% {
    -webkit-transform: scale(1.5) rotate(10deg);
            transform: scale(1.5) rotate(10deg);
            opacity: 0;
  }

  100% {
    -webkit-transform: scale(1) rotate(0deg);
            transform: scale(1) rotate(0deg);
    opacity: 1;
  }
}


/* delay 
-------------------- */
.anime-delay-100 {
  -webkit-animation-delay: 0.1s !important;
  animation-delay: 0.1s !important;
  transition-delay: 0.1s !important;
}

.anime-delay-200 {
  -webkit-animation-delay: 0.2s !important;
  animation-delay: 0.2s !important;
  transition-delay: 0.2s !important;
}

.anime-delay-300 {
  -webkit-animation-delay: 0.3s !important;
  animation-delay: 0.3s !important;
  transition-delay: 0.3s !important;
}

.anime-delay-400 {
  -webkit-animation-delay: 0.4s !important;
  animation-delay: 0.4s !important;
  transition-delay: 0.4s !important;
}

.anime-delay-500 {
  -webkit-animation-delay: 0.5s !important;
  animation-delay: 0.5s !important;
  transition-delay: 0.5s !important;
}

.anime-delay-600 {
  -webkit-animation-delay: 0.6s !important;
  animation-delay: 0.6s !important;
  transition-delay: 0.6s !important;
}

.anime-delay-700 {
  -webkit-animation-delay: 0.7s !important;
  animation-delay: 0.7s !important;
  transition-delay: 0.7s !important;
}

.anime-delay-800 {
  -webkit-animation-delay: 0.8s !important;
  animation-delay: 0.8s !important;
  transition-delay: 0.8s !important;
}

.anime-delay-900 {
  -webkit-animation-delay: 0.9s !important;
  animation-delay: 0.9s !important;
  transition-delay: 0.9s !important;
}

.anime-delay-1000 {
  -webkit-animation-delay: 1s !important;
  animation-delay: 1s !important;
  transition-delay: 1s !important;
}

.anime-delay-1100 {
  -webkit-animation-delay: 1.1s !important;
  animation-delay: 1.1s !important;
  transition-delay: 1.1s !important;
}

.anime-delay-1200 {
  -webkit-animation-delay: 1.2s !important;
  animation-delay: 1.2s !important;
  transition-delay: 1.2s !important;
}

.anime-delay-1300 {
  -webkit-animation-delay: 1.3s !important;
  animation-delay: 1.3s !important;
  transition-delay: 1.3s !important;
}

.anime-delay-1400 {
  -webkit-animation-delay: 1.4s !important;
  animation-delay: 1.4s !important;
  transition-delay: 1.4s !important;
}

.anime-delay-1500 {
  -webkit-animation-delay: 1.5s !important;
  animation-delay: 1.5s !important;
  transition-delay: 1.5s !important;
}

.anime-delay-1600 {
  -webkit-animation-delay: 1.6s !important;
  animation-delay: 1.6s !important;
  transition-delay: 1.6s !important;
}

.anime-delay-1700 {
  -webkit-animation-delay: 1.7s !important;
  animation-delay: 1.7s !important;
  transition-delay: 1.7s !important;
}

.anime-delay-1800 {
  -webkit-animation-delay: 1.8s !important;
  animation-delay: 1.8s !important;
  transition-delay: 1.8s !important;
}

.anime-delay-1900 {
  -webkit-animation-delay: 1.9s !important;
  animation-delay: 1.9s !important;
  transition-delay: 1.9s !important;
}

.anime-delay-2000 {
  -webkit-animation-delay: 2s !important;
  animation-delay: 2s !important;
  transition-delay: 2s !important;
}

.anime-delay-2100 {
  -webkit-animation-delay: 2.1s !important;
  animation-delay: 2.1s !important;
  transition-delay: 2.1s !important;
}

.anime-delay-2200 {
  -webkit-animation-delay: 2.2s !important;
  animation-delay: 2.2s !important;
  transition-delay: 2.2s !important;
}