@charset "UTF-8";
.productArea {
  margin-top: 140px;
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  .productArea {
    margin-top: 100px;
  }
}
@media screen and (max-width: 767px) {
  .productArea {
    margin-top: calc( 97/780 * 100vw);
  }
}

.productList .proItem {
  padding: 170px 0 270px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .productList .proItem {
    padding: calc( 150/1920 * 100vw) 0 calc( 220/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .productList .proItem {
    padding: calc( 130/1280 * 100vw) 0 calc( 180/1280 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .productList .proItem {
    padding: calc( 440/780 * 100vw) 0 calc( 125/780 * 100vw);
  }
}
.productList .proItem.item01 {
  background: url("/assets/img/product/img_product_01.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item01 {
    background-image: url("/assets/img/product/img_product_01_sp.jpg");
  }
}
.productList .proItem.item02 {
  background: url("/assets/img/product/img_product_02.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item02 {
    background-image: url("/assets/img/product/img_product_02_sp.jpg");
  }
}
.productList .proItem.item03 {
  background: url("/assets/img/product/img_product_03.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item03 {
    background-image: url("/assets/img/product/img_product_03_sp.jpg");
  }
}
.productList .proItem.item04 {
  background: url("/assets/img/product/img_product_04.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item04 {
    background-image: url("/assets/img/product/img_product_04_sp.jpg");
  }
}
.productList .proItem.item05 {
  background: url("/assets/img/product/img_product_05.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item05 {
    background-image: url("/assets/img/product/img_product_05_sp.jpg");
  }
}
.productList .proItem.item06 {
  background: url("/assets/img/product/img_product_06.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item06 {
    background-image: url("/assets/img/product/img_product_06_sp.jpg");
  }
}
.productList .proItem.item07 {
  background: url("/assets/img/product/img_product_07.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item07 {
    background-image: url("/assets/img/product/img_product_07_sp.jpg");
  }
}
.productList .proItem.item08 {
  background: url("/assets/img/product/img_product_08.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .productList .proItem.item08 {
    background-image: url("/assets/img/product/img_product_08_sp.jpg");
  }
}

.explanWrap {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .explanWrap.sectionInner {
    padding-right: calc( 30/780 * 100vw);
  }
}
.explanWrap .productNum {
  display: inline-block;
  font-size: 3rem;
  font-weight: 700;
  border-bottom: 2px solid #fff;
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .explanWrap .productNum {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .explanWrap .productNum {
    font-size: calc( 40/780 * 100vw);
  }
}
.explanWrap .vegeTtl {
  margin-top: 70px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .explanWrap .vegeTtl {
    margin-top: calc( 70/1920 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .explanWrap .vegeTtl {
    margin-top: calc( 70/780 * 100vw);
  }
}
.explanWrap .vegeTtl .big {
  font-size: 6rem;
  font-weight: 700;
  line-height: 1.3333333333;
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .explanWrap .vegeTtl .big {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .explanWrap .vegeTtl .big {
    font-size: calc( 60/780 * 100vw);
  }
}
.explanWrap .vegeTtl .small {
  margin-top: 6px;
  font-size: 4rem;
  font-weight: 700;
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .explanWrap .vegeTtl .small {
    font-size: 3rem;
  }
}
@media screen and (max-width: 767px) {
  .explanWrap .vegeTtl .small {
    font-size: calc( 40/780 * 100vw);
  }
}
.explanWrap .detailTxt {
  margin-top: 200px;
  font-size: 2.4rem;
  line-height: 2;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .explanWrap .detailTxt {
    margin-top: calc( 180/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .explanWrap .detailTxt {
    margin-top: calc( 160/1280 * 100vw);
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .explanWrap .detailTxt {
    margin-top: calc( 200/780 * 100vw);
    font-size: calc( 28/780 * 100vw);
    line-height: 1.8571428571;
  }
}

/* ===============================================
# モーダル（中身）
=============================================== */
.js-open-modal {
  cursor: pointer;
}

.modal {
  display: none;
  justify-content: flex-end;
  align-items: center;
  position: fixed;
  z-index: 8888;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  padding: 25px 0;
  overflow-y: auto;
}
@media screen and (max-width: 767px) {
  .modal {
    padding: calc( 20/780 * 100vw) 0;
  }
}
.modal .modal-overlay {
  position: fixed;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.modal .modal-content {
  position: relative;
  width: 100%;
  max-width: 100%;
  max-height: 100%;
}
.modal .modal-content .modal-close {
  position: absolute;
  top: 40px;
  right: 90px;
  width: 48px;
  height: 48px;
  cursor: pointer;
  z-index: 10;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .modal .modal-content .modal-close {
    top: calc( 40/1920 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .modal .modal-content .modal-close {
    top: calc( 30/780 * 100vw);
    right: calc( 56/780 * 100vw);
    width: calc( 48/780 * 100vw);
    height: calc( 48/780 * 100vw);
  }
}
.modal .modal-content .modal-close::before, .modal .modal-content .modal-close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40px;
  height: 2px;
  background: #005f30;
}
@media screen and (max-width: 767px) {
  .modal .modal-content .modal-close::before, .modal .modal-content .modal-close::after {
    width: calc( 46/780 * 100vw);
  }
}
.modal .modal-content .modal-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modal .modal-content .modal-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.modal .modal-content .modal-container {
  padding-bottom: 25px;
  margin: 0 50px;
}
@media screen and (max-width: 767px) {
  .modal .modal-content .modal-container {
    padding-bottom: calc( 20/780 * 100vw);
    margin: 0 calc( 20/780 * 100vw);
  }
}
.modal .modal-content .modal-bg {
  background-color: rgba(255, 255, 255, 0.8);
}
.modal .modal-content .modal-inner {
  display: flex;
  align-items: flex-end;
  gap: 60px;
  margin: 0 auto;
  padding: 150px 40px 200px;
  max-width: 1380px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .modal .modal-content .modal-inner {
    gap: calc( 58/1920 * 100vw);
    padding: calc( 150/1920 * 100vw) calc( 50/1920 * 100vw) calc( 210/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1700px) {
  .modal .modal-content .modal-inner {
    align-items: flex-start;
    gap: 1.1764705882vw;
    padding: 8.8235294118vw 1.1764705882vw 10.5882352941vw 5.8823529412vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  .modal .modal-content .modal-inner {
    padding: 9.0909090909vw 1.8181818182vw 9.0909090909vw 5.4545454545vw;
  }
}
@media screen and (max-width: 767px) {
  .modal .modal-content .modal-inner {
    display: block;
    padding: calc( 100/780 * 100vw) calc( 76/780 * 100vw) calc( 100/780 * 100vw);
  }
}
.modal .modal-content .explanWrap {
  color: #005f30;
}
.modal .modal-content .explanWrap .productNum {
  border-color: #005f30;
}
@media screen and (max-width: 767px) {
  .modal .modal-content .explanWrap .productNum {
    line-height: 1.2;
  }
}
@media screen and (max-width: 767px) {
  .modal .modal-content .explanWrap .detailTxt {
    margin-top: calc( 40/780 * 100vw);
  }
}
.modal .modal-content .productImg {
  position: relative;
  bottom: -50px;
}
@media screen and (max-width: 767px) {
  .modal .modal-content .productImg {
    position: static;
  }
}
.modal .modal-content .productImg {
  width: 792px;
  max-width: 100%;
  min-width: 350px;
  margin-right: -200px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  .modal .modal-content .productImg {
    width: calc( 720/1920 * 100vw);
    margin-right: calc( -190/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1700px) {
  .modal .modal-content .productImg {
    margin-right: -2.9411764706vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .modal .modal-content .productImg {
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .modal .modal-content .productImg {
    width: calc( 560/780 * 100vw);
    min-width: auto;
    margin-left: calc( 80/780 * 100vw);
    margin-right: 0;
    margin-top: calc( 20/780 * 100vw);
  }
}

#modalOne .modal-overlay {
  background: url("/assets/img/product/img_product_01.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalOne .modal-overlay {
    background-image: url("/assets/img/product/img_product_01_sp.jpg");
  }
}

#modalTwo .modal-overlay {
  background: url("/assets/img/product/img_product_02.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalTwo .modal-overlay {
    background-image: url("/assets/img/product/img_product_02_sp.jpg");
  }
}
#modalTwo .modal-inner {
  gap: 0;
}
#modalTwo .productImg {
  margin-right: -210px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalTwo .productImg {
    margin-right: calc( -190/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1700px) {
  #modalTwo .productImg {
    margin-right: -2.9411764706vw;
  }
}
@media screen and (max-width: 767px) {
  #modalTwo .productImg {
    margin-left: calc( 60/780 * 100vw);
  }
}

#modalThree .modal-overlay {
  background: url("/assets/img/product/img_product_03.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalThree .modal-overlay {
    background-image: url("/assets/img/product/img_product_03_sp.jpg");
  }
}
@media screen and (min-width: 1701px) and (max-width: 1920px) {
  #modalThree .modal-inner {
    gap: calc( 80/1920 * 100vw);
  }
}
#modalThree .productImg {
  width: 570px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalThree .productImg {
    width: calc( 550/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #modalThree .productImg {
    width: calc( 400/1280 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  #modalThree .productImg {
    width: calc( 390/780 * 100vw);
    margin-left: calc( 110/780 * 100vw);
  }
}

#modalFour .modal-overlay {
  background: url("/assets/img/product/img_product_04.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalFour .modal-overlay {
    background-image: url("/assets/img/product/img_product_04_sp.jpg");
  }
}
#modalFour .productImg {
  bottom: -20px;
  margin-left: -100px;
  margin-right: -233px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalFour .productImg {
    margin-left: calc( -100/1920 * 100vw);
    margin-right: calc( -233/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1700px) {
  #modalFour .productImg {
    margin-right: -2.9411764706vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #modalFour .productImg {
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  #modalFour .productImg {
    width: calc( 500/780 * 100vw);
    margin-left: calc( 80/780 * 100vw);
    margin-right: 0;
  }
}

#modalFive .modal-overlay {
  background: url("/assets/img/product/img_product_05.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalFive .modal-overlay {
    background-image: url("/assets/img/product/img_product_05_sp.jpg");
  }
}
#modalFive .productImg {
  bottom: -100px;
  margin-left: -100px;
  margin-right: -233px;
  width: 800px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalFive .productImg {
    margin-left: calc( -200/1920 * 100vw);
    margin-right: calc( -233/1920 * 100vw);
    width: calc( 770/1920 * 100vw);
  }
}
@media screen and (min-width: 768px) and (max-width: 1700px) {
  #modalFive .productImg {
    margin-left: -5.8823529412vw;
    margin-right: -2.9411764706vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  #modalFive .productImg {
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  #modalFive .productImg {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  #modalFive .detailTxt {
    margin-top: 0;
  }
}

#modalSix .modal-overlay {
  background: url("/assets/img/product/img_product_06.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalSix .modal-overlay {
    background-image: url("/assets/img/product/img_product_06_sp.jpg");
  }
}
#modalSix .productImg {
  width: 800px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalSix .productImg {
    width: calc( 770/1920 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  #modalSix .productImg {
    margin-left: calc( 30/780 * 100vw);
  }
}

#modalSeven .modal-overlay {
  background: url("/assets/img/product/img_product_07.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalSeven .modal-overlay {
    background-image: url("/assets/img/product/img_product_07_sp.jpg");
  }
}
#modalSeven .productImg {
  bottom: -20px;
  width: 680px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalSeven .productImg {
    width: calc( 620/1920 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  #modalSeven .productImg {
    width: calc( 540/780 * 100vw);
    margin-left: calc( 50/780 * 100vw);
  }
}

#modalEight .modal-overlay {
  background: url("/assets/img/product/img_product_08.jpg") no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  #modalEight .modal-overlay {
    background-image: url("/assets/img/product/img_product_08_sp.jpg");
  }
}
#modalEight .productImg {
  width: 680px;
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
  #modalEight .productImg {
    width: calc( 650/1920 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  #modalEight .productImg {
    width: calc( 540/780 * 100vw);
    margin-left: calc( 50/780 * 100vw);
  }
}