@charset "utf-8";

/* ---------------------------------------------
Reset
--------------------------------------------- */
/* Modern browser */
*,
*::before,
*::after{box-sizing:border-box}
*{margin:0;padding:0;}
img,
picture,
video,
canvas,
svg{display:block;max-width:100%}
input,
button,
textarea,
select{font:inherit}
p,
h1,
h2,
h3,
h4,
h5,
h6{overflow-wrap:break-word}


/* addition */
img,
video {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media screen and (min-width: 768px) {
  img {
    width: auto;
  }
}
em {
  font-style: normal;
}
small {
  font-size: 70%;
}

ul,ol,li {
  padding: 0;
  list-style: none;
}


/* ---------------------------------------------
font
--------------------------------------------- */
html {
  font-family: 'Noto Sans JP', sans-serif;
}

html body,
table th,
table td {
  line-height: 1.6;
  color: #000;
  font-size: 3.4vw;
}
@media screen and (min-width: 768px) {
  html body,
  table th,
  table td {
    font-size: 16px;
  }
}

strong, em {
  font-weight: 700;
}


/* ---------------------------------------------
link
--------------------------------------------- */
/* a,
a:link,
a:visited {
  color: #1e87f0;
}
a:hover {
  color: #f01e1e;
  text-decoration: none;
} */


/* ---------------------------------------------
width
--------------------------------------------- */
.wrapper {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .wrapper {
    width: 750px;
  }
  .sp_only {
    display: none!important;
  }
}
@media screen and (max-width: 767px) {
  .pc_only {
    display: none!important;
  }
}

.contentsWrapper {
  width: 94.667%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .contentsWrapper {
    width: 640px;
  }
}

/* ---------------------------------------------
cmn
--------------------------------------------- */
.page_cmn .sec {
  margin: 0;
}
.page_cmn .sec .secTitle {
  margin: 0;
}

.page_cmn sup {
  font-size: 40%;
  vertical-align: super;
}

.page_cmn .btn a:hover {
  filter: saturate(130%);
}

.page_cmn .red1 {
  color: #d50001;
}
.page_cmn .blu1 {
  color: #00008a;
}

.page_cmn .taC {
  text-align: center;
}
.page_cmn .taR {
  text-align: right;
}


.page_cmn .note small {
  font-size: 3.4vw;
  display: block;
}
@media screen and (min-width: 768px) {
  .page_cmn .note small {
    font-size: 17px;
  }
  .page_cmn .note1 small {
    text-indent: -1em; 
  }
}
.page_cmn .note1 small {
  padding-left: 1em;
  text-indent: -0.7rem;
  color: #fff;;
  line-height: 1.6;
}
.page_cmn .note2 small {
  padding-left: 2em;
  text-indent: -2em;
}

.page_cmn .supplement {
  margin: 0 0 30px;
}
.page_cmn .supplement .SupplementList {
  margin: 0;
}
.page_cmn .supplement .SupplementList li {
  margin: 0 0 10px;
  padding: 0 0 0 1.3em;
  position: relative;
}
.page_cmn .supplement .SupplementList li:before {
  content: '\25CF';/* ● */
  position: absolute;
  top: 0;
  left: 0;
}

/* animation */
.page_cmn .js-animation {
  opacity: 0;
  transform: translateY(1em);
  transition: all 1s;
}
.page_cmn .js-animation.active {
  opacity: 1;
  transform: translateY(0);
}
.page_cmn .js-animation.delay1 {
  transition-delay: .5s;
}


/* cta */
.page_cmn .cta .ctaBg {
  padding: 0 0 3em;
  color: #fff;
  background-color: #cc675f;
}
.page_cmn .cta1 .ctaArea {
  margin: 0 0 1em;
  padding-bottom: 2em;
  background: url(/Landing/formlp/Images/rereje_rich/sp/240801/images/sec1_bg1.jpg) no-repeat center top #efefef;
  background-size: 100% auto;
  border: 1.467vw solid #cc675f;
  position: relative;
}
@media screen and (min-width: 768px) {
  .page_cmn .cta1 .ctaArea {
    border-width: 11px;
  }
}
.page_cmn .cta1 .ctaArea .ctaTtl {
  margin-bottom: -1.5em;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .page_cmn .cta1 .ctaArea .ctaTtl {
    margin-bottom: -3em;
  }
}
.page_cmn .cta1 .ctaArea .ctaTxt1 {
  position: relative;
  z-index: 1;
  display: block;
}
.page_cmn .cta1 .ctaArea .ctaBtnArea {
  width: 100%;
}
.page_cmn .cta1 .ctaArea .ctaBtnArea .btn {
  width: 98.49%;
  margin: 0 auto;
}
.page_cmn .cta1 .ctaNoteSt1 {
  width: 95%;
  margin: 0 auto;
}
.page_cmn .cta1 .ctaNoteSt1 .noteTtl {
  margin: 0 1em .5em;
  text-align: center;
  font-size: 4.5vw;
  font-weight: 400;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .page_cmn .cta1 .ctaNoteSt1 .noteTtl {
    font-size: 25px;
  }
}
.page_cmn .cta1 .ctaNoteSt1 .noteTtl::before,
.page_cmn .cta1 .ctaNoteSt1 .noteTtl::after {
  content: '';
  width: 4em;
  height: 2px;
  margin: 0 .5em;
  background-color: #fff;
}

/* btn_animation */
.btn_animation {
  animation: .5s bound-anim ease-in infinite alternate;
}
@keyframes bound-anim{
  0%{
    transform: translateY(0) scale(1);
  }
  60%{
    transform: translateY(1.734vw) scale(1);
  }
  100%{
    transform: translateY(3.2vw) scale(1.02, 0.95);
  }
}
@media screen and (min-width: 768px) {
  @keyframes bound-anim{
    0%{
      transform: translateY(0) scale(1);
    }
    60%{
      transform: translateY(13px) scale(1);
    }
    100%{
      transform: translateY(24px) scale(1.02, 0.95);
    }
  }
}

/* swiper */
.page_cmn .swiper-slide {
  overflow: hidden;
  cursor: grab;
}
.page_cmn .swiper-slide:active {
  cursor: grabbing;
}
.page_cmn .swiper-button-next,
.page_cmn .swiper-button-prev {
  color: #6a6a6a;
  transform: translateY(-50%);
}
.page_cmn .swiper-button-next {
  right: 1.5%;
}
.page_cmn .swiper-button-prev {
  left: 1.5%;
}
@media screen and (min-width: 768px) {
  .page_cmn .swiper-button-next {
    right: 2.5%;
  }
  .page_cmn .swiper-button-prev {
    left: 2.5%;
  }
}
.swiper-wrapper {
  transition-timing-function: linear;
  width: 375px;
}
.swiper-button-next:after, .swiper-button-prev:after {
  font-size: 7vw;
}
@media screen and (min-width: 768px) {
  .swiper-button-next:after, .swiper-button-prev:after {
    font-size: 45px;
  }
}


/* ---------------------------------------------
#mainContents
--------------------------------------------- */
#mainContents {
  position: relative;
  z-index: 2;
}


/* contentHeader */
#mainContents .contentHeader .pageTitle {
  position: relative;
}
#mainContents .contentHeader .pageTitle .mainCopy {
  width: 28.134%;
  position: absolute;
  top: 2vw;
  left: 0;
  z-index: 2;
  display: block;
}
@media screen and (min-width: 768px) {
  #mainContents .contentHeader .pageTitle .mainCopy {
    top: 20px;
  }
}
#mainContents .contentHeader .pageTitle .bg {
  position: relative;
  z-index: 1;
  display: block;
}



/* contents */
#mainContents #sec1 .baArea {
  padding: 0 0 2.5em;
  background-color: #f9f2ec;
  position: relative;
}
#mainContents #sec1 .baArea .slider {
  width: 81.734%;
  margin: 0 auto;
}


#mainContents #sec3 .ugcArea {
  padding: .2em 0 2em;
  background: url(/Landing/formlp/Images/rereje_rich/sp/240801/images/sec3_bg1.jpg) no-repeat center top;
  background-size: 100% 100%;
}
#mainContents #sec3 .ugcArea .ugc1 {
  margin-bottom: 13px;
}


#mainContents #sec4 .videoArea {
  position: relative;
}
#mainContents #sec4 .videoArea .video {
  width: 93.334%;
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 2;
  transform: translateX(-50%);
}
#mainContents #sec4 .videoArea .bg {
  position: relative;
  z-index: 1;
  display: block;
}


#mainContents #sec5 .achievements {
  position: relative;
}
#mainContents #sec5 .achievements .graph {
  width: 59.2%;
  position: absolute;
  bottom: 10%;
  left: 50%;
  z-index: 2;
  transform: translateX(-50%);
}
#mainContents #sec5 .achievements .graph li:first-child {
  margin-bottom: 2em;
}
#mainContents #sec5 .achievements .bg {
  position: relative;
  z-index: 1;
}


#mainContents #sec7 .videoArea1 {
  padding: 3em 0;
  background-color: #c6d1d7;
}
#mainContents #sec7 .videoArea1 .video {
  width: 93.334%;
  margin: 0 auto;
}


#mainContents #sec8 .videoArea {
  position: relative;
}
#mainContents #sec8 .videoArea .video {
  width: 90%;
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: 2;
  transform: translateX(-50%);
}
#mainContents #sec8 .videoArea .bg {
  position: relative;
  z-index: 1;
}


#mainContents #sec11 .videoArea {
  background-color: #eee4da;
}
#mainContents #sec11 .videoArea .video {
  width: 92%;
  margin: 0 auto;
}


#mainContents #sec13 {
  padding: 3em 0 2em;
  background-color: #ebebeb;
}
#mainContents #sec13 .secTitle {
  width: 50%;
  margin: 0 auto 2em;
}
#mainContents #sec13 .faq .faqBlock {
  margin-bottom: 1.5em;
}
.formlp-front-section #mainContents #sec13 .faq .faqCont p {
  padding: 1em;
  font-size: 4vw;
  background-color: #fff;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .formlp-front-section #mainContents #sec13 .faq .faqCont p {
    font-size: 28px;
  }
}


#mainContents #sec14 {
  margin-bottom: 3em;
  padding: 3em 0 2em;
}
#mainContents #sec14 .figImg {
  margin-bottom: 3em;
}
#mainContents #sec14 .itemDetail {
  margin-bottom: 3em;
}
#mainContents #sec14 .itemDetail .ttlArea {
  margin-bottom: .8em;
  padding-bottom: .8em;
  text-align: center;
}
#mainContents #sec14 .itemDetail .ttlArea .ttl {
  font-size: 4vw;
  font-weight: 600;
  position: relative;
}
@media screen and (min-width: 768px) {
  #mainContents #sec14 .itemDetail .ttlArea .ttl {
    font-size: 28px;
  }
}
#mainContents #sec14 .itemDetail .ttlArea .ttl::after {
  content: '';
  width: 8em;
  height: 1px;
  background-color: #cc675f;
  position: absolute;
  top: calc(100% + .4em);
  left: 50%;
  transform: translateX(-50%);
}
#mainContents #sec14 .itemDetail .content p {
  text-align: center;
  font-size: 26px;
  font-size: 3.8vw;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  #mainContents #sec14 .itemDetail .content p {
    font-size: 26px;
    line-height: 1.6;
  }
}
#mainContents #sec14 .itemDetail3 .content {
  text-align: left;
}
#mainContents #sec14 .efficacy {
  padding: 1em;
  text-align: center;
  border: 1px solid #6a6a6a;
  position: relative;
}
#mainContents #sec14 .efficacy {
  padding: 2em 1em 1em;
  text-align: center;
  border: 1px solid #6a6a6a;
  position: relative;
}
#mainContents #sec14 .efficacy .ttlArea {
  line-height: 1;
  font-size: 4.2vw;
  position: absolute;
  top: -.6em;
  right: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  #mainContents #sec14 .efficacy .ttlArea {
    font-size: 30px;
  }
}
#mainContents #sec14 .efficacy .ttlArea .ttl {
  padding: 0 1em;
  font-weight: 400;
  background-color: #fff;
  display: inline-block;
}
#mainContents #sec14 .efficacy .content p {
  font-size: 3.8vw;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  #mainContents #sec14 .efficacy .content p {
    font-size: 26px;
    line-height: 1.6;
  }
}


/* ---------------------------------------------
#pageFooter
--------------------------------------------- */
#pageFooter {
  padding: 5em 0 30vw;
}
@media screen and (min-width: 768px) {
  #pageFooter {
    padding-bottom: 250px;
  }
}
#pageFooter .logo {
  width: 28.8vw;
  margin: 0 auto 4em;
}
@media screen and (min-width: 768px) {
  #pageFooter .logo {
    width: 216px;
  }
}
#pageFooter .footer_nav {
  margin: 0 0 5em;
  text-align: center;
}
#pageFooter .footer_nav ul li {
  font-size: 4.5vw;
  line-height: 1.6;
}
#pageFooter .footer_nav ul li a {
  color: #000;
  text-decoration: none;
  font-size: 4.5vw;
}
@media screen and (min-width: 768px) {
  #pageFooter .footer_nav ul li a {
    font-size: 28px;
  }
  #pageFooter .footer_nav ul li {
    font-size: 4.5vw;
    line-height: 1;
  }
}
#pageFooter .footer_nav ul li a:hover {
  text-decoration: underline;
}


#pageFooter .copyright {
  padding: 1.5em 0;
  text-align: center;
  color: #fff;
  font-size: 2vw;
  background-color: #238162;
}
@media screen and (min-width: 768px) {
  #pageFooter .copyright {
    font-size: 14px;
  }
}


.fixedBtn {
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 1000;
  display: none;
}
@media screen and (min-width: 768px) {
  .wrapper {
    width: 640px;
  }
  .fixedBtn {
    width: 750px;
    left: 50%;
    transform: translateX(-50%);
  }
}
