@charset "UTF-8";
/* スマホの記述  480px*/
@media screen and (max-width: 480px) {
  /* ========================================
  共通
  ======================================== */
  .pc_on {
    display: none !important;
  }
  .sp_on {
    display: block !important;
  }
  .pc_on480 {
    display: none;
  }
  .sp_on480 {
    display: block;
  }
  /* ========================================
  メニュー
  ======================================== */
  .wrpper {
    padding: 0 0 430px;
  }
  body.no-scroll {
    overflow: hidden;
    position: fixed;
    width: 100%;
  }
  .nav-open:hover .btn-trigger {
    height: 10px;
  }
  @keyframes morphing_none {
    0% {
      width: calc(100% - 30px);
      height: calc(100vh - 30px);
      max-height: 805px;
      border-radius: 20px;
    }
    80% {
      border-radius: 200px 40px 200px 200px;
      width: 200px;
      height: 200px;
    }
    90% {
      border-radius: 100px 40px 100px 100px;
      width: 100px;
      height: 100px;
    }
    100% {
      border-radius: 20px 40px 20px 20px;
      width: 60px;
      height: 60px;
    }
  }
  .active_none.nav-content {
    animation: morphing_none 0.2s ease-in forwards;
  }
  @keyframes morphing {
    0% {
      border-radius: 20px 40px 20px 20px;
      width: 60px;
      height: 60px;
      left: auto;
    }
    10% {
      border-radius: 100px 40px 100px 100px;
      width: 100px;
      height: 100px;
    }
    20% {
      border-radius: 200px 40px 200px 200px;
      width: 200px;
      height: 200px;
    }
    99% {
      left: auto;
    }
    100% {
      width: calc(100% - 30px);
      height: 100%;
      height: calc(var(--vh) - 30px);
      border-radius: 20px 20px 20px 20px;
    }
  }
  .active.nav-content {
    position: fixed;
    top: 15px;
    right: 15px;
    bottom: 15px;
    left: 15px;
    padding: 30px 30px 30px;
    max-height: inherit;
    height: auto;
    display: flex;
    align-items: center;
    animation: morphing 0.2s ease-in forwards;
  }
  .menu_product_img {
    width: 25%;
    transition: 0.3s;
  }
  .global-box__list {
    width: 100%;
  }
  .global-box__list--text {
    display: flex;
    gap: 30px;
    align-items: center;
  }
  .menu_text {
    font-size: 5vw;
    margin: -10px 0 0;
  }
  .menu_link_btn {
    font-size: 5vw;
  }
  /* ========================================
  ローダー
  ======================================== */
  .loader-bg_inner {
    height: 82%;
  }
  .progress-bar {
    height: 18%;
  }
  .progress-textArea {
    bottom: 19%;
  }
  /* ========================================
  mv
  ======================================== */
  .mv {
    position: relative;
    overflow: hidden;
    min-height: inherit;
  }
  .mv .mv_inner {
    min-height: inherit;
    height: 82%;
  }
  .mv_product_in {
    position: relative;
    display: flex;
    gap: 20px;
    width: 80%;
    margin: 0 auto;
  }
  .mv_product_img {
    cursor: pointer;
    position: relative;
    width: 30%;
  }
  .mv_product {
    width: 100%;
  }
  .mv .logo {
    left: 15px;
  }
  .mv_product_spImg1 {
    width: 78%;
    margin: -20px auto;
    position: relative;
    z-index: 830;
  }
  .mv_treatment_sp1 {
    left: -5px;
  }
  /* ========================================
  about
  ======================================== */
  .about {
    margin: 20px 0 0;
    background-size: contain;
    position: relative;
    background-image: url(../img/bg/abbg_sp.gif) !important;
  }
  .about .about_in {
    padding: 295px 20px 100px;
  }
  .about .about_text1 {
    top: -140px;
    right: -10px;
    width: 70%;
  }
  .about .about_text2 {
    width: 80%;
    top: -240px;
    left: 5px;
  }
  .about .about_textArea {
    margin: 20px 0 10px;
  }
  .mv_product_spImg2 {
    width: 78%;
    margin: 25px auto;
    position: relative;
    z-index: 10;
  }
  .about .about_treatment1 {
    width: 57%;
    top: 155px;
  }
  .about .about_treatment2 {
    width: 30%;
    bottom: auto;
    top: 259px;
    left: -10px;
  }
  .about .about_treatment3 {
    width: 50%;
    top: 230px;
    right: -60px;
  }
  .about .about_logo {
    width: 70%;
  }
  .about .js_about_text2 {
    opacity: 1;
    transform: translateY(0px);
  }
  .about .js_about_text1 {
    opacity: 1;
    transform: translateY(0px);
  }
  .about .about_treatment1_js {
    transform: translateX(0%);
  }
  .about .about_treatment2_js {
    transform: translateX(0%);
  }
  .about .about_treatment3_js {
    transform: translateX(0%);
  }
  /* ========================================
  商品紹介
  ======================================== */
  .product {
    margin: 0px 0 0;
  }
  .product .product_under {
    margin: 80px 0 0;
    padding: 0px 0 70px;
  }
  .product .product_about_logo1 {
    margin: 30px auto 0;
    width: 77%;
  }
  .product .product_treatment1 {
    max-width: 795px;
    width: 78%;
    top: -100px;
  }
  .product .product_treatment2 {
    top: -165px;
  }
  .product .product_plan_title {
    font-size: 11.5vw;
    text-align: center;
  }
  .product .pro_bubble {
    width: 85%;
  }
  .product .product_under_img img {
    transform: translateX(0%);
    transform: translateY(20px);
  }
  .product .active.js_product_under_img img {
    transform: translateY(0px);
  }
  .product .active.js_product_plan {
    transition-duration: 0.6s;
    transition-delay: 0.6s;
  }
  .product .product_plan {
    transform: translateY(20px);
  }
  .product .product_treatment3 img {
    transform: translateX(15%);
    opacity: 0;
  }
  .product .active.js_product_treatment.product_treatment3 img {
    transform: translateX(12%);
  }
  .product .product_treatment3 {
    width: 87%;
  }
  /* ========================================
  お客様の声
  ======================================== */
  .voice {
    padding: 70px 0 100px;
  }
  .pc_on_950.none {
    display: block;
  }
  .voice .voice_box {
    margin: 60px 0 0;
    position: relative;
    height: auto;
    padding: 0 20px;
  }
  .voice .voice_text1 {
    width: 65%;
    margin: 0;
  }
  .voice .voice_text1 {
    transform: inherit;
  }
  .voice .voice_subTitle {
    font-size: 5.8vw;
  }
  .voice .voice_sentence1 {
    margin: 10px 0 0 0;
  }
  .voice .voice_text {
    width: 100%;
    margin: 0;
    transform: inherit;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .voice .voice_text3, .voice .voice_text4 {
    flex-direction: row-reverse;
  }
  .voice .voice_text:not(:first-of-type) {
    margin: 40px 0 0;
    width: 100%;
  }
  .voice .voice_woman1, .voice .voice_woman2, .voice .voice_woman3, .voice .voice_woman4 {
    position: relative;
    top: auto;
    right: auto;
    left: auto;
    bottom: auto;
  }
  .voice_text_in {
    width: 65%;
  }
  .voice_text_in3 {
    width: 74%;
  }
  .voice_text_in2 {
    width: 74%;
  }
  .voice_text_in4 {
    width: 69%;
  }
  .voice .voice_woman1 {
    width: 30%;
  }
  .voice .voice_woman3 {
    width: 21%;
  }
  .voice .voice_woman2 {
    width: 21%;
  }
  .voice .voice_woman4 {
    width: 26%;
  }
  .voice .voice_merchandise {
    margin: 40px auto 0;
    width: 75%;
  }
  /* ========================================
  レシピ
  ======================================== */
  .recipe {
    padding: 80px 0 0px;
  }
  .recipe .recipe_in {
    padding: 60px 0 70px;
  }
  .recipe .recipe_in_bg {
    position: absolute;
    top: 0px;
    bottom: 0;
    right: 0;
    left: 0;
    background-image: url(../img/bg/abbg_sp.gif) !important;
    background-position: center 0px;
    background-size: contain;
    background-repeat: repeat-y;
    padding: 0 0 150px;
    z-index: -1;
  }
  .splide__slide .recipe_title {
    height: 65px !important;
    font-size: 6vw;
    line-height: 1.3;
    margin: 0px 0 15px;
  }
  .splide__slide.is-active .splide__slide__in {
    transform: scale(0.95) !important;
  }
  .splide__slide.is-active .slide_img .slide_link_btn {
    transform: scale(0.9) !important;
  }
  .splide__slide.is-active .slide_img img {
    transform: scale(0.9) !important;
  }
  .recipe .recipe_box .slide_img img {
    transform: scale(0.85);
  }
  .recipe .splide__slide__in {
    transform: scale(0.85);
  }
  .recipe .splide__track {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .slide_logo_sp {
    width: 78%;
    margin: 85px auto 0;
  }
  .slide_bubble_sp {
    width: 68%;
  }
  .recipe .splide__track {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .recipe .btn_recipe {
    margin: 15px auto 0;
  }
  .slider-wrapper {
    margin: -20px 0 0;
  }
  .slider-wrapper2, .slider-wrapper3 {
    margin: -20px 0 0;
  }
  .recipe .splide__slide .btn_recipe {
    margin-top: 27px;
  }
  .slide_bubble_sp {
    margin: 24px auto 0px;
  }
  .recipe .splide__arrow {
    opacity: 1;
    top: 50%;
  }
  .recipe .splide__arrow--next {
    background-size: 20px;
    width: 35px;
    height: 35px;
  }
  .recipe .splide__arrow--prev {
    background-size: 20px;
    width: 35px;
    height: 35px;
  }
  /* ========================================
  フッター
  ======================================== */
  .footer .copy {
    margin: 30px 0 0;
  }
  .footer {
    height: 430px;
  }
}
/* ===========================================
スマホの記述  375px
============================================*/
@media screen and (max-width: 375px) {
  .product .product_treatment2 {
    top: -145px;
  }
  .product .product_treatment3 {
    max-width: 755px;
    top: -120px;
    width: 82%;
  }
}
/* ===========================================
スマホの記述  320px
============================================*/
@media screen and (max-width: 320px) {
  .about .about_in {
    padding: 275px 20px 100px;
  }
  .about .about_sub_title {
    font-size: 1.7rem;
  }
  .about .about_title {
    font-size: 7vw;
  }
  .about .about_text1 {
    top: -130px;
  }
  .about .about_text2 {
    top: -210px;
  }
  .about .about_treatment2 {
    width: 30%;
    bottom: auto;
    top: 239px;
    left: 0px;
  }
  .about .about_treatment3 {
    right: -50px;
  }
  .about .about_textArea {
    margin: 135px 0 10px;
  }
  .about {
    margin: 0px 0 0;
  }
}
/* ========================================
スマホ横向きになった時
======================================== */
@media screen and (orientation: landscape) and (max-width: 926px) and (max-height: 428px) {
  /* ========================================
  共通
  ======================================== */
  .pc_on {
    display: none !important;
  }
  .sp_on {
    display: block !important;
  }
  .pc_on480 {
    display: none;
  }
  .sp_on480 {
    display: block;
  }
  /* ========================================
  メニュー
  ======================================== */
  .nav-open:hover .btn-trigger {
    height: 10px;
  }
  @keyframes morphing_none {
    0% {
      width: calc(100% - 30px);
      height: calc(100vh - 30px);
      max-height: 805px;
      border-radius: 20px;
    }
    80% {
      border-radius: 200px 40px 200px 200px;
      width: 200px;
      height: 200px;
    }
    90% {
      border-radius: 100px 40px 100px 100px;
      width: 100px;
      height: 100px;
    }
    100% {
      border-radius: 20px 40px 20px 20px;
      width: 60px;
      height: 60px;
    }
  }
  .active_none.nav-content {
    animation: morphing_none 0.35s ease-in forwards;
  }
  @keyframes morphing {
    0% {
      border-radius: 20px 40px 20px 20px;
      width: 60px;
      height: 60px;
      left: auto;
    }
    10% {
      border-radius: 100px 40px 100px 100px;
      width: 100px;
      height: 100px;
    }
    20% {
      border-radius: 200px 40px 200px 200px;
      width: 200px;
      height: 200px;
    }
    99.9% {
      left: auto;
    }
    100% {
      width: calc(100% - 30px);
      height: calc(100vh - 30px);
      border-radius: 20px 20px 20px 20px;
    }
  }
  .active.nav-content {
    position: fixed;
    top: 15px;
    right: 15px;
    bottom: 15px;
    left: 15px;
    padding: 30px 30px 30px;
    max-height: inherit;
    height: auto;
    display: flex;
    align-items: center;
    animation: morphing 0.35s ease-in forwards;
  }
  .menu_product_img {
    width: 25%;
    transition: 0.3s;
  }
  .global-box__list {
    width: 100%;
  }
  .global-box__list--text {
    display: flex;
    gap: 30px;
    align-items: center;
  }
  .menu_text {
    font-size: 5vw;
    margin: -10px 0 0;
  }
  .menu_link_btn {
    font-size: 5vw;
  }
  /* ========================================
  mv
  ======================================== */
  .mv {
    position: relative;
    overflow: hidden;
    min-height: inherit;
  }
  .mv .mv_inner {
    min-height: inherit;
    height: 82%;
  }
  .mv_product_in {
    position: relative;
    display: flex;
    gap: 20px;
    width: 80%;
    margin: 0 auto;
  }
  .mv_product_img {
    cursor: pointer;
    position: relative;
    width: 30%;
  }
  .mv_product {
    width: 100%;
  }
  .mv .logo {
    left: 15px;
  }
  .mv_product_spImg1 {
    width: 58%;
    margin: -65px auto;
    position: relative;
    z-index: 830;
  }
  .mv_treatment_sp1 {
    left: -5px;
  }
  /* ========================================
  about
  ======================================== */
  .about {
    margin: 100px 0 0;
    background-size: contain;
    position: relative;
  }
  .about .about_in {
    padding: 415px 20px 100px;
  }
  .about .about_text1 {
    top: -270px;
    right: -10px;
    width: 70%;
  }
  .about .about_text2 {
    width: 80%;
    top: -490px;
    left: 5px;
  }
  .about .about_textArea {
    margin: 20px 0 10px;
  }
  .mv_product_spImg2 {
    width: 78%;
    margin: 25px auto;
    position: relative;
    z-index: 10;
  }
  .about .about_treatment1 {
    width: 57%;
    top: 155px;
  }
  .about .about_treatment2 {
    width: 30%;
    bottom: auto;
    top: 329px;
    left: -10px;
  }
  .about .about_treatment3 {
    width: 50%;
    top: 270px;
    right: -60px;
  }
  .about .about_logo {
    width: 70%;
  }
  .about .js_about_text2 {
    opacity: 1;
    transform: translateY(0px);
    padding: 90px 0 0;
  }
  .about .js_about_text1 {
    opacity: 1;
    transform: translateY(0px);
  }
  .about .about_treatment1_js {
    transform: translateX(0%);
  }
  .about .about_treatment2_js {
    transform: translateX(0%);
  }
  .about .about_treatment3_js {
    transform: translateX(0%);
  }
  /* ========================================
  商品紹介
  ======================================== */
  .product {
    margin: 0px 0 0;
  }
  .product .product_under {
    margin: 80px 0 0;
    padding: 0px 0 70px;
  }
  .product .product_about_logo {
    opacity: 1;
  }
  .product .product_about_logo1 {
    margin: 30px auto 0;
    width: 77%;
  }
  .product .product_treatment1 {
    max-width: 795px;
    width: 78%;
    top: -100px;
  }
  .product .product_treatment2 {
    top: -165px;
  }
  .product .product_plan_title {
    font-size: 11.5vw;
    text-align: center;
  }
  .product .pro_bubble {
    width: 85%;
  }
  .product .product_under_img img {
    transform: translateX(0%);
    transform: translateY(20px);
  }
  .product .active.js_product_under_img img {
    transform: translateY(0px);
  }
  .product .active.js_product_plan {
    transition-duration: 0.6s;
    transition-delay: 0.6s;
  }
  .product .product_plan {
    transform: translateY(20px);
  }
  .product .product_treatment3 img {
    transform: translateX(15%);
    opacity: 0;
  }
  .product .active.js_product_treatment.product_treatment3 img {
    transform: translateX(12%);
  }
  .product .product_treatment3 {
    width: 87%;
  }
  /* ========================================
  お客様の声
  ======================================== */
  .voice {
    padding: 70px 0 100px;
  }
  .pc_on_950.none {
    display: block;
  }
  .voice .voice_box {
    margin: 60px 0 0;
    position: relative;
    height: auto;
    padding: 0 20px;
  }
  .voice .voice_text1 {
    width: 65%;
    margin: 0;
  }
  .voice .voice_text1 {
    transform: inherit;
  }
  .voice .voice_subTitle {
    font-size: 5.8vw;
  }
  .voice .voice_sentence1 {
    margin: 10px 0 0 0;
  }
  .voice .voice_text {
    width: 100%;
    margin: 0;
    transform: inherit;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .voice .voice_text3, .voice .voice_text4 {
    flex-direction: row-reverse;
  }
  .voice .voice_text:not(:first-of-type) {
    margin: 40px 0 0;
    width: 100%;
  }
  .voice .voice_woman1, .voice .voice_woman2, .voice .voice_woman3, .voice .voice_woman4 {
    position: relative;
    top: auto;
    right: auto;
    left: auto;
    bottom: auto;
  }
  .voice_text_in {
    width: 65%;
  }
  .voice_text_in3 {
    width: 74%;
  }
  .voice_text_in2 {
    width: 74%;
  }
  .voice_text_in4 {
    width: 69%;
  }
  .voice .voice_woman1 {
    width: 30%;
  }
  .voice .voice_woman3 {
    width: 21%;
  }
  .voice .voice_woman2 {
    width: 21%;
  }
  .voice .voice_woman4 {
    width: 26%;
  }
  .voice .voice_merchandise {
    margin: 40px auto 0;
    width: 75%;
  }
  /* ========================================
  レシピ
  ======================================== */
  .recipe {
    padding: 80px 0 50px;
  }
  .recipe .recipe_in {
    padding: 60px 0 0;
  }
  .recipe .recipe_in_bg {
    position: absolute;
    top: 0px;
    bottom: 0;
    right: 0;
    left: 0;
    background-image: url(../img/slide1/sl1_bg_sp.png);
    background-position: center 0px;
    background-size: contain;
    background-repeat: repeat-y;
    padding: 0 0 150px;
    z-index: -1;
  }
  .recipe .splide__slide.is-active {
    transform: scale(1);
  }
  .recipe .recipe_box .slide_img img {
    transform: scale(0.85);
  }
  .recipe .splide__slide {
    transform: scale(0.85);
  }
  .recipe .splide__track {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .slide_logo_sp {
    width: 78%;
    margin: 85px auto 0;
  }
  .slide_bubble_sp {
    width: 68%;
  }
  .recipe .splide__track {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .recipe .recipe_title {
    margin: 0px 0 0px;
  }
  .recipe .btn_recipe {
    margin: 15px auto 0;
  }
  .slider-wrapper {
    margin: -50px 0 0;
  }
  /* ========================================
  フッター
  ======================================== */
  .footer .copy {
    margin: 30px 0 0;
  }
  .footer {
    height: 430px;
  }
}
@media screen and (max-width: 380px) and (max-height: 720px) {
  /* メインビジュ流調整 */
  .logo {
    width: 75px;
  }
  .mv .mv_img {
    width: 90%;
  }
  .loader_img {
    width: 90%;
  }
  .active.nav-content {
    align-items: inherit;
  }
}/*# sourceMappingURL=sp.css.map */