@charset "UTF-8";

/*==================================================
#kv
==================================================*/
#kv {
  position: relative;
}
#kv-slider .swiper-slide > img{
  height: 100%;
  object-fit: cover;
  max-width: unset;
}
#kv-slider .swiper-slide{
  height: auto;
}
#kv-slider .swiper-slide.slide01{
  background: #e6e6e6;
}
#kv-slider .swiper-slide.slide02{
  background: #d9d1cf;
}
#kv-slider .swiper-slide.slide03{
  background: #edeef0;
}
#kv h1{
  text-align: center;
  font-weight: 900;
  position: absolute;
  z-index: 2;
  top:50%;
  right: 8rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
#kv h1 *{
  font-weight: unset;
  line-height: 140%;
}
#kv h1 figure{
  margin: 2rem auto;
}
#kv h1 .catch{
  color: #FC6210;
}
#kv .slide03 h1{
  right: auto;
  top: 65%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
#kv h1 small br.hide{
  display: none;
}
#kv-slider{
  position: relative;
  z-index: 1;
}
#kv-slider .swiper-pagination{
  position: relative;
}
.swiper-container-horizontal > .swiper-pagination-bullets{
  margin-top: -4rem;
  bottom: 0;
}
.swiper-pagination-bullet {
  font-family: futura-pt, sans-serif;
  font-size: 3rem;
  font-weight: 900;
  width: 8rem;
  height: 8rem;
  background: #ffffff;
  color: var(--color_ocher);
  border: 3px solid var(--color_ocher);
  line-height: 7.5rem;
  opacity: 1;
  outline: none;
}
.swiper-pagination-bullet-active {
  color: var(--color_purple);
  border-color: var(--color_purple);
}
#kv .swiper-slide-active h1 p,
#kv .swiper-slide-active h1 figure{
  animation: SlideIn 1s forwards;
}
@keyframes SlideIn {
  0% {
    opacity: 0;
    transform: translateX(100px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
  @media screen and (min-width: 1241px) {
    #kv h1{
      font-size: 4rem;
    }
    #kv h1 figure{
      width: 600px;
    }
    #kv h1 small{
      font-size: var(--font_large);
    }
  }
  @media screen and (max-width: 1240px) {
    #kv h1{
      font-size: var(--font_x_large);
      right: 4rem;
    }
    #kv h1 figure{
      width: 400px;
    }
    #kv h1 small{
      font-size: var(--font_medium);
    }
    .swiper-container-horizontal > .swiper-pagination-bullets{
      margin-top: -3rem;
      bottom: 0;
    }
    .swiper-pagination-bullet {
      font-size: 2rem;
      width: 6rem;
      height: 6rem;
      line-height: 5.5rem;
    }
  }
  @media screen and (max-width: 768px) {
    #kv-slider .swiper-wrapper{
      height: 95vh;
    }
    #kv h1{
      font-size: 3rem;
      width: 100%;
      top: auto;
      bottom: 7rem;
      right: auto;
      left: 50%;
      -webkit-transform: translateX(-50%);
      transform: translateX(-50%);
    }
    #kv h1 *{
      line-height: 120%;
    }
    #kv-slider .swiper-slide.slide03 h1{
      top: auto;
      bottom: 10rem;
    }
    #kv h1 small{
      margin-top: 10px;
      font-size: 2rem;
    }
  }
  @media screen and (max-width: 600px) {
    #kv h1{
      font-size: 5vw;
      bottom: 5rem;
    }
    #kv h1 figure{
      width: 75%;
      margin: 0.5rem auto 1rem;
    }
    #kv h1 .catch{
      font-size: 4vw;
    }
    #kv h1 small{
      margin-top: 10px;
      font-size: 4vw;
    }
    #kv h1 small br{
      display: none;
    }
    #kv h1 small br.hide{
      display: block;
    }
    #kv-slider .swiper-slide.slide01 > img{
      height: 90vh;
    }
  }

/*==================================================
#sec-reason
==================================================*/
#sec-reason{
  padding-top: calc(var(--space_section) * 2);
  padding-bottom: calc(var(--space_section) * 2);
}
#sec-reason .point > div{
  display: flex;
  flex-direction: column;
}
#sec-reason .point p{
  margin-bottom: var(--space_m);
}
#sec-reason .point figure{
  margin-top: auto;
}
#sec-reason .point figcaption{
  color: #867468;
  text-align: right;
  font-size: var(--font_small);
  margin-bottom: calc(var(--space_m) / 1.5);
}
  @media screen and (min-width: 751px) {
  }
  @media screen and (max-width: 768px) {
    #sec-reason{
      padding-top: var(--space_section);
      padding-bottom: var(--space_section);
    }
  }


/*==================================================
#sec-lineup
==================================================*/
.bg01{
  padding-top: 90vh;
  background: url(/common/variecross/img/img_home_bg01.jpg) no-repeat center bottom / cover;
}
  @media screen and (max-width: 1024px) {
    .bg01{
      padding-top: 70vh;
    }
  }
  @media screen and (min-width: 769px) {
    #sec-lineup{
      padding-top: 0;
      margin-top: -2.5rem;
    }
  }
  @media screen and (max-width: 768px) {
    .bg01{
      padding-top: 90vh;
      background-position: center left 60%;
    }
  }


/*==================================================
#sec-appeal
==================================================*/
#sec-appeal{
  padding: 0;
}
#sec-appeal .inner{
  padding: calc(var(--space) * 1.5) 0;
}
#sec-appeal figure{
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  height: 100%;
}
#sec-appeal figure img{
  max-height: 100%;
  width: auto;
}
#sec-appeal .ttl{
  margin: var(--space) 0 0;
  font-size: 5rem;
}
#sec-appeal .ttl span{
  line-height: 140%;
}
#sec-appeal .ttl em{
  font-size: 7rem;
  line-height: 140%;
}
  @media screen and (max-width: 1240px) {
    #sec-appeal .ttl{
      font-size: 5vmin;
    }
    #sec-appeal .ttl em{
      font-size: 6vmin;
    }
    #sec-appeal figure{
      right: 8rem;
    }
  }
  @media screen and (max-width: 900px) {
    #sec-appeal .inner{
      padding: var(--space) 0;
    }
    #sec-appeal .ttl{
      margin-top: calc(var(--space) * 2);
    }
    #sec-appeal .ttl span{
      background: #fff;
    }
    #sec-appeal figure{
      right: 0;
    }
  }


/*==================================================
#sec-featur
==================================================*/
#sec-feature .ttl{
  margin: 0;
}
#sec-feature p.pc{
  margin-top: calc(-10% + 5rem);
  margin-right: calc(100% / 3 + 1rem);
}
  @media screen and (min-width: 1025px) {
    #sec-feature .point h3{
      display: block;
    }
    #sec-feature .point h3 em{
      display: block;
      padding-bottom: 0.5rem;
    }
    #sec-feature .point h3 em:after{
      padding-left: 0.5rem;
    }
    #sec-feature .point > div:first-child{
      margin-top: -10%;
    }
    #sec-feature .point > div:nth-child(3){
      margin-top: 10%;
    }
  }
  @media screen and (max-width: 1000px) {
    #sec-feature .point > div{
      display: flex;
      flex-direction: column;
    }
    #sec-feature .point > div:not(:nth-child(3)) figure{
      margin-top: auto;
    }
    #sec-feature .point p.sp{
      padding: 0 var(--space_m);
      margin-top: calc(var(--space_m) * 3);
    }
  }
  @media screen and (max-width: 1000px) and (min-width: 551px) {
    #sec-feature .pc{
      display: none;
    }
    #sec-feature .point p.sp{
      display: block;
      width: calc(100% / 2);
    }
  }


/*==================================================
#sec-efficacy
==================================================*/
#sec-efficacy{
  padding-bottom: 0;
  position: relative;
  z-index: 2;
}
#sec-efficacy .inner{
  max-width: 1000px;
  background: #fff;
  padding: 5%;
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0,0,0,0.3));
  filter: drop-shadow(0px 0px 10px rgba(0,0,0,0.3));
}
#sec-efficacy .ttl{
  text-align: center;
  font-size: 5rem;
}
#sec-efficacy .ttl span{
  padding-top: calc(var(--space_m) * 2);
  padding-bottom: 0;
}
#sec-efficacy .ttl span:before{
  content: '';
  display: block;
  position: absolute;
  top: 9px;
  right: 0;
  width: calc(100% - 190px - 1rem);
  border-bottom: 2px solid var(--color_base);
}
#sec-efficacy .ttl span:after{
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 190px;
  height: 18px;
  background: url(/common/variecross/img/logo_variecross.svg) no-repeat center / contain;
}
#sec-efficacy .ttl small{
  font-size: var(--font_large);
  font-weight: 600;
}
#sec-efficacy .efficacy{
  display: flex;
  margin: 0 calc(-1 * var(--space_m));
}
#sec-efficacy .efficacy figure{
  flex: 1;
  margin: 0 var(--space_m);
}
#sec-efficacy .subttl{
  margin: calc(var(--space_m) * 2) auto var(--space_m);
}
#sec-efficacy dl{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#sec-efficacy dt{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6rem;
  border: 1px solid var(--color_base);
  margin-top: var(--space_m);
}
#sec-efficacy dd{
  width: calc(100% - 8rem);
  margin-top: var(--space_m);
}
#sec-efficacy dt.result{
  background: var(--color_base);
  color: #fff;
}
  @media screen and (max-width: 768px) {
    #sec-efficacy .inner{
      padding: 7rem;
    }
    #sec-efficacy .ttl{
      font-size: 4rem;
    }
    #sec-efficacy .ttl span:before{
      top: 7.5px;
      width: calc(100% - 150px - 1rem);
    }
    #sec-efficacy .ttl span:after{
      width: 150px;
      height: 15px;
    }
    #sec-efficacy .ttl small{
      font-size: var(--font_medium);
    }
  }
  @media screen and (max-width: 550px) {
    #sec-efficacy .inner{
      padding: var(--space) 2rem 2rem;
    }
    #sec-efficacy .ttl{
      font-size: 6.5vmin;
    }
    #sec-efficacy .ttl span{
      padding-top: 15px;
    }
    #sec-efficacy .ttl span:before{
      top: 3px;
      width: calc(100% - 95px - 0.5rem);
    }
    #sec-efficacy .ttl span:after{
      width: 95px;
      height: 9px;
    }
    #sec-efficacy .ttl small{
      font-size: var(--font_base);
    }
    #sec-efficacy .ttl small br{
      display: none;
    }
    #sec-efficacy .efficacy{
      display: block;
    }
    #sec-efficacy .efficacy figure{
      margin-bottom: var(--space_m);
    }
  }


/*==================================================
#sec-health
==================================================*/
#sec-health{
  position: relative;
  z-index: 1;
  margin-top: -13%;
  padding-top: calc(var(--space_section) * 4);
  padding-bottom: calc(var(--space_section) * 7);
  background: #A1C8F3 url(/common/variecross/img/img_home_bg02.jpg) no-repeat center bottom / 100%;
}
#sec-health .ttl{
  text-align: center;
}
#sec-health .subttl em{
  color: #fff;
}
  @media screen and (min-width: 751px) {
  }
  @media screen and (max-width: 1000px) {
    #sec-health .point > div:last-child{
      width: 100%;
    }
  }
  @media screen and (max-width: 768px) {
    #sec-health{
      padding-top: calc(var(--space_section) * 2.5);
      padding-bottom: calc(var(--space_section) * 4.5);
    }
  }


/*==================================================
#sec-quality
==================================================*/
#sec-quality .point figure{
  margin-bottom: var(--space_m);
}
#sec-quality{
  background: var(--color_blue);
}
#sec-quality .point{
  max-width: var(--width_inner_px);
  width: 90%;
  margin: 0 auto;
}
  @media screen and (min-width: 1480px) {
    #sec-quality{
      background: none;
      padding-bottom: calc(var(--space_section) + 10rem);
    }
    #sec-quality .ttl{
      font-size: 6rem;
    }
    #sec-quality .point{
      max-width: var(--width_inner_px);
      width: 90%;
      margin: 0 auto;
      box-sizing: initial;
      position: relative;
    }
    #sec-quality .point:before{
      content: '';
      position: absolute;
      z-index: -2;
      top: -15rem;
      left: -10rem;
      width: 100%;
      height: 100%;
      background: var(--color_blue);
      border: 10rem solid var(--color_blue);
      padding-top: 5rem;
    }
    #sec-quality .point:after{
      content: '';
      position: absolute;
      z-index: -1;
      top:50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      width: 100%;
      height: 100%;
      background: #fff;
      border: 5rem solid #fff;
      -webkit-filter: drop-shadow(0px 0px 10px rgba(0,0,0,0.1));
      filter: drop-shadow(0px 0px 10px rgba(0,0,0,0.1));
    }
    #sec-quality .point figure{
      margin-bottom: var(--space_m);
    }
  }
  @media screen and (min-width: 1025px) {
    #sec-quality .ttl{
      font-size: 6rem;
    }
    #sec-quality .point h3{
      display: block;
    }
    #sec-quality .point h3 em{
      display: block;
      padding-bottom: 0.5rem;
    }
    #sec-quality .point h3 em:after{
      padding-left: 0.5rem;
    }
  }
  @media screen and (max-width: 1000px) and (min-width: 551px){
    #sec-quality .point > div:last-child{
      width: 100%;
      display: flex;
    }
    #sec-quality .point > div:last-child .txt-wrap{
      flex: 1;
      padding-right: var(--space_m);
    }
    #sec-quality .point > div:last-child figure{
      flex: 1;
      order: 2;
      padding-left: var(--space_m);
    }
  }


/*==================================================
#sec-voice
==================================================*/
#sec-voice .point{
  padding: calc(var(--space) / 1.5) 0 var(--space);
}
#sec-voice .point > div:nth-child(4){
  flex: 2;
}
  @media screen and (min-width: 751px) {
  }
  @media screen and (max-width: 768px) {
    #sec-voice .point > div:nth-child(4){
      order: 5;
    }
  }


/*==================================================
#sec-footcart
==================================================*/
#sec-footcart{
  background:#EAEAEA;
  border-bottom: 1px solid var(--color_blue);
  padding-top: 0;
}
#sec-footcart .intro{
  position: relative;
}
#sec-footcart .intro .txt-wrap .ttl{
  text-align: center;
  font-size: 3.5rem;
}
#sec-footcart .intro .txt-wrap h3{
  font-weight: 900;
  margin-top: calc(var(--space_m) * 2);
}
#sec-footcart .cart01,
#sec-footcart .cart02{
  display: flex;
  align-items: flex-end;
  margin: 0 calc(-1 * var(--space_m));
}
#sec-footcart .cart01 figure, #sec-footcart .cart01 .txt-wrap,
#sec-footcart .cart02 figure, #sec-footcart .cart02 .txt-wrap{
  flex: 1;
  padding: 0 var(--space_m);
}
#sec-footcart .cart01{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
#sec-footcart .cart01 figure{
  opacity: 0;
  height: 1px;
}
#sec-footcart .txt-wrap h3{
  font-size: 2rem;
  font-weight: 700;
  margin: 1rem auto;
}
#sec-footcart .txt-wrap dl{
  line-height: 140%;
}
#sec-footcart .txt-wrap dt{
  float: left;
  overflow: hidden;
  width: 8rem;
  padding-bottom: 1rem;
}
#sec-footcart .txt-wrap dd{
  display: block;
  padding-left: 9rem;
  padding-bottom: 1rem;
}
#sec-footcart .caution-area{
  background: #fff;
  padding: 5rem;
  margin: var(--space) auto 0;
}
#sec-footcart .caution-area h4{
  font-size: var(--font_medium);
  font-weight: 700;
  margin-bottom: 3rem;
}
#sec-footcart .caution-area ul li{
  margin-top: 1rem;
  position: relative;
  padding-left: var(--space_m);
}
#sec-footcart .caution-area ul li:before{
  content: '・';
  position: absolute;
  left: 0;
}
  @media screen and (min-width: 901px) {
    #sec-footcart .intro .inner{
      position: absolute;
      top:50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
    }
  }
  @media screen and (min-width: 1025px) {
    #sec-footcart .intro .txt-wrap h3{
      font-size: 3.5rem;
    }
    #sec-footcart .intro .txt-wrap{
      width: calc(600 / var(--width_inner) * 100%);
    }
    #sec-footcart .caution-area{
      padding: 7rem 10rem;
    }
  }
  @media screen and (max-width: 1240px) {
    #sec-footcart{
      padding-right: 0;
    }
    #sec-footcart .intro .txt-wrap{
      width: 50%;
    }
    #sec-footcart .intro .txt-wrap h3{
      font-size: var(--font_x_large);
    }
    #sec-footcart .intro .txt-wrap h3 br{
      display: block;
    }
    #sec-footcart .inner{
      padding-right: 8rem;
    }
    #sec-footcart .cart01{
      position: relative;
    }
    #sec-footcart .cart02{
      margin-top: -10rem;
    }
  }
  @media screen and (max-width: 900px) {
    #sec-footcart .inner{
      padding-right: 0;
    }
    #sec-footcart .intro .inner{
      padding: 8rem 0;
    }
    #sec-footcart .intro .txt-wrap{
      width: 100%;
      text-align: center;
    }
    #sec-footcart .intro .txt-wrap .ttl{
      margin: 0;
    }
    #sec-footcart .intro .txt-wrap img{
      width: 50%;
      margin: 0 auto;
      display: block;
    }
    #sec-footcart .intro figure{
      display: none;
    }
    #sec-footcart .cart01 figure{
      opacity: 1;
      height: auto;
    }
    #sec-footcart .cart02{
      margin-top: var(--space);
    }
    #sec-footcart .caution-area{
      padding: var(--space) 2rem;
    }
  }
  @media screen and (max-width: 500px) {
    #sec-footcart .intro .txt-wrap .ttl{
      font-size: var(--font_large);
    }
    #sec-footcart .intro .txt-wrap img{
      width: 100%;
    }
    #sec-footcart .intro .txt-wrap h3{
      font-size: var(--font_medium);
    }
    #sec-footcart .cart01,
    #sec-footcart .cart02{
      display: block;
    }
  }
