/* 014 */

@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap");

body {
  margin: 0 0;
  padding: 0 0;
}

body .header {
  z-index: 20;
  width: 95.8333333333vw;
  height: 7.0465277778vw;
  position: absolute;
  background-color: rgba(255, 255, 255, 0.7);
  margin: 1.3888888889vw 2.0833333333vw 0;
  display: flex;
  align-items: center;
  color: #003f7e;
  justify-content: space-between;
}

body .header .stlassh {
  margin-left: 2.7777777778vw;
  width: 11.1111111111vw;
  height: 4.7916666667vw;
}

body .header .headerFlex {
  display: flex;
  justify-content: space-between;
  font-size: 1.1111111111vw;
  font-size: 1.2vw;
  margin-left: 10%;
}

body .header .headerFlex ul {
  justify-content: center;
  white-space: nowrap;
}

body .header .headerFlex li {
  display: inline;
  padding: 0 4%;
}

body .header .account {
  display: flex;
  margin-right: 3.5vw;
}

body .header .account a {
  text-decoration: none;
}

body .header .account .logIn {
  text-align: center;
  margin-left: 3.3vw;
  width: 9.1666666667vw;
  height: 3.0555555556vw;
  font-size: 0.9722222222vw;
  line-height: 3.0555555556vw;
  border: solid 0.0694444444vw #003f7e;
  border-radius: 1.5277777778vw;
  font-weight: bold;
}

body .header .account .logIn span {
  color: #003f7e;
}

body .header .account .Registration {
  text-align: center;
  margin-left: 1.1111111111vw;
  width: 9.1666666667vw;
  height: 3.0555555556vw;
  font-size: 0.9722222222vw;
  line-height: 3.0555555556vw;
  border: solid 0.0694444444vw #003f7e;
  border-radius: 1.5277777778vw;
  font-weight: bold;
  background-color: #003f7e;
  color: #ffffff;
}

body .header .account .Registration span {
  color: #ffffff;
}

@media (max-width: 899.9px) {
  body .header {
    display: none;
  }
}

body .cartIcon {
  position: fixed;
  right: 0;
  background-color: #003f7e;
  z-index: 20;
  padding: clamp(0px, 4.6153846154vw, 27.5px);
  bottom: clamp(0px, 16.4102564103vw, 80px);
}

body .cartIcon .shoppingCart {
  width: clamp(0px, 7.1794871795vw, 35px);
  height: clamp(0px, 7.1794871795vw, 35px);
}

body .firstView {
  position: relative;
  z-index: 2;
}

@media (max-width: 899.9px) {
  body .firstView {
    padding: 4.4871794872vw;
    height: calc(100vh - 8.9743589744vw);
  }
}

@media (min-width: 900px) {
  body .firstView {
    padding: 2.7777777778vw;
    height: calc(100vh - 5.5555555556vw);
  }
}

@media (max-width: 899.9px) {
  body .firstView .stlassh {
    z-index: 2;
    position: absolute;
    top: clamp(0px, 10.2564102564vw, 40px);
    left: clamp(0px, 10.2564102564vw, 45px);
    width: 29.4871794872vw;
    height: 12.8205128205vw;
  }
}

@media (min-width: 900px) {
  body .firstView .stlassh {
    display: none;
  }
}

body .firstView .fv {
  position: relative;
  width: 100%;
}

@media (max-width: 899.9px) {
  body .firstView .fv {
    height: calc(100% - 14.8717948718vw);
  }
}

@media (min-width: 900px) {
  body .firstView .fv {
    height: calc(100% - 4.4444444444vw);
  }
}

@media (max-width: 499.9px) {
  body .firstView .fvPc {
    display: none;
  }
}

@media (min-width: 500px) {
  body .firstView .fvSp {
    display: none;
  }
}

body .firstView .fv img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

body .firstView .scrollDown {
  position: absolute;
  right: 0;
  background-color: #ffffff;
}

@media (max-width: 899.9px) {
  body .firstView .scrollDown {
    width: 81.2820512821vw;
    height: 30vw;
    bottom: 12%;
  }
}

@media (min-width: 900px) {
  body .firstView .scrollDown {
    width: 47.8472222222vw;
    height: 19.4444444444vw;
    bottom: 0%;
  }
}

body .firstView .scrollDown .fvText {
  color: #003f7e;
}

@media (max-width: 899.9px) {
  body .firstView .scrollDown .fvText {
    width: 49.2307692308vw;
    height: 22.3076923077vw;
    line-height: 7.4358974359vw;
    font-size: 4.1025641026vw;
    margin: 3.8461538462vw auto;
    margin-left: 11.5384615385vw;
  }
}

@media (min-width: 900px) {
  body .firstView .scrollDown .fvText {
    width: 33.3333333333vw;
    height: 15vw;
    line-height: 5vw;
    font-size: 2.7777777778vw;
    margin: 2.2222222222vw auto;
    margin-left: 3.8888888889vw;
  }
}

body .firstView .scrollDown img {
  position: absolute;
}

@media (max-width: 899.9px) {
  body .firstView .scrollDown img {
    width: 3.5897435897vw;
    height: 21.5384615385vw;
    bottom: 2.5641025641vw;
    right: 5.1282051282vw;
  }
}

@media (min-width: 900px) {
  body .firstView .scrollDown img {
    width: 1.7361111111vw;
    height: 10.4166666667vw;
    bottom: 6.8055555556vw;
    right: 5.5555555556vw;
  }
}

body .brandConcept {
  margin-top: 40px;
  position: relative;
  z-index: 1;
}

body .brandConcept .mist {
  position: absolute;
  z-index: 2;
}

@media (max-width: 899.9px) {
  body .brandConcept .mist {
    margin-top: -46.1538461538vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .mist {
    width: 62.2916666667vw;
    height: 62.2916666667vw;
    margin-top: -56.9444444444vw;
    margin-left: 10.8333333333vw;
  }
}

body .brandConcept .itemImgFlex {
  position: relative;
  z-index: 3;
}

@media (max-width: 899.9px) {
  body .brandConcept .itemImgFlex {
    display: flex;
    padding: 3.5897435897vw 13.0769230769vw 0;
  }

  body .brandConcept .itemImgFlex .lipbalm {
    width: 17.9487179487vw;
    height: 28.2051282051vw;
    margin-top: 7.1794871795vw;
    z-index: 3;
  }

  body .brandConcept .itemImgFlex .faceMask {
    width: 29.4871794872vw;
    height: 29.2307692308vw;
    margin-left: -6.4102564103vw;
    z-index: 1;
  }

  body .brandConcept .itemImgFlex .facialWash {
    width: 30.7692307692vw;
    height: 38.4615384615vw;
    margin-left: -9.7435897436vw;
    margin-top: -1.5384615385vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .itemImgFlex {
    display: none;
  }
}

body .brandConcept .conceptBody {
  position: relative;
  z-index: 3;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody {
    margin-top: 12.8205128205vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody {
    display: flex;
  }
}

body .brandConcept .conceptBody .backgroundImgWrap {
  position: absolute;
  overflow: hidden;
  width: 100vw;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .backgroundImgWrap {
    height: 153.8461538462vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .backgroundImgWrap {
    margin-top: -16.6666666667vw;
    height: 54.1666666667vw;
  }
}

body .brandConcept .conceptBody .backgroundImgWrap .backgroundImg {
  z-index: 4;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .backgroundImgWrap .backgroundImg {
    width: 200vw;
    height: 153.8461538462vw;
    margin-left: -25.641025641vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .backgroundImgWrap .backgroundImg {
    width: 69.4444444444vw;
    height: 54.1666666667vw;
    margin-left: -3.4722222222vw;
  }
}

body .brandConcept .conceptBody .conceptText {
  position: relative;
  z-index: 5;
  font-size: clamp(0px, 3.5897435897vw, 18px);
  color: #003f7e;
  line-height: 250%;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .conceptText {
    padding: 0 10.2564102564vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .conceptText {
    width: 50.625vw;
    margin: 0 7.2222222222vw 0 5.5555555556vw;
    margin-top: 2.7986111111vw;
  }
}

body .brandConcept .conceptBody .dropImgFlex {
  display: flex;
  position: relative;
  z-index: 5;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .dropImgFlex .drop1 {
    margin-left: 3.8461538462vw;
    margin-top: 5.1282051282vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .dropImgFlex .drop1 {
    margin-top: 5.1282051282vw;
  }
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .dropImgFlex .drop2 {
    margin-left: -6.6666666667vw;
    margin-top: 18.7179487179vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .dropImgFlex .drop2 {
    margin-left: -5.6152777778vw;
    margin-top: 18.7179487179vw;
  }
}

body .brandConcept .conceptBody .dropImgFlex .drop3 {
  margin-left: -6.4102564103vw;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .dropImgFlex .drop3 {
    margin-left: -6.4102564103vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .dropImgFlex .drop3 {
    margin-left: -13.1152777778vw;
  }
}

body .brandConcept .conceptBody .dropImgFlex .drop {
  position: relative;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .dropImgFlex .drop {
    width: 35.1282051282vw;
    height: 36.4102564103vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .dropImgFlex .drop {
    width: 16.2402777778vw;
    height: 16.8326388889vw;
  }
}

body .brandConcept .conceptBody .dropImgFlex .drop .dropText {
  text-align: center;
  position: absolute;
  color: #003f7e;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

@media (max-width: 899.9px) {
  body .brandConcept .conceptBody .dropImgFlex .drop .dropText {
    font-size: 2.8205128205vw;
    width: 19.7435897436vw;
  }
}

@media (min-width: 900px) {
  body .brandConcept .conceptBody .dropImgFlex .drop .dropText {
    font-size: 1.3039375vw;
    width: 9.1666666667vw;
  }
}

.brand_Concept .conceptBody .conceptText {
  padding: 0 40px;
}

.hadaterasuLogo {
  width: 180px;
}

.brand_Concept .conceptBody .conceptText p {
  font-size: clamp(11px, 1.2vw, 15px);
  font-family: "Klee One", "Noto Sans JP", sans-serif !important;
  margin-bottom: 25px;
}

.brand_Concept .conceptBody .conceptText .mainCopy {
  font-size: clamp(21px, 1.9vw, 30px);
  line-height: 2.4rem;
  margin-top: 48px;
}

.brand_Concept .conceptBody {
  position: relative;
  z-index: 3;
  max-width: 800px;
  margin: 0 auto;
}

.brand_Concept .backgroundImgWrap {
  position: absolute;
  top: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-bottom-left-radius: 1000px 300px;
  border-bottom-right-radius: 1000px 300px;
}

.brand_Concept .backgroundImgWrap .backgroundImg {
  width: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 899.9px) {
  .brand_Concept .backgroundImgWrap .backgroundImg {
    height: 100%;
  }
}

@media (min-width: 900px) {
  .brand_Concept .backgroundImgWrap .backgroundImg {
    height: 140%;
  }
}

.brand_Concept .conceptBody .conceptText {
  position: relative;
  z-index: 5;
  font-size: clamp(0px, 3.5897435897vw, 18px);
  color: #373737;
  line-height: 2rem;
  padding-top: 25%;
}

.conceptHadaterasu {
  position: relative;
  z-index: 5;
  width: 50%;
  margin: -5% auto 10%;
}

body .product {
  position: relative;
  z-index: 2;
  margin-top: 40px;
}

body .product .productContentsWrap {
  position: relative;
  overflow: hidden;
}

body .product .productContentsWrap .productContent {
  position: absolute;
  z-index: 3;
  overflow: hidden;
  box-shadow: 0.1px -0.1px 4px 0 rgba(0, 63, 126, 0.2);
  background-color: #e4f3ff;
}

@media (max-width: 899.9px) {
  body .product .productContentsWrap .productContent {
    --height: clamp(0px,
        100vh - clamp(0px, 22.0512820513vw, 120px) - 20px - 86px,
        139.4871794872vw);
    width: calc(var(--height) / 544 * 350);
    height: var(--height);
    margin: 0 calc((100vw - var(--height) / 544 * 350) / 2);
    bottom: calc((100vh - clamp(0px, 22.0512820513vw, 120px) - 20px - 86px - var(--height)) / 2);
    border-radius: calc(0.037 * var(--height));
  }
}

@media (min-width: 900px) {
  body .product .productContentsWrap .productContent {
    --height: clamp(0px,
        100vh - clamp(0px, 22.0512820513vw, 120px) - 20px - 86px,
        min(34.7222222222vw, 500px));
    width: calc(var(--height) / 500 * 1380);
    height: var(--height);
    margin: 0 calc((100vw - var(--height) / 500 * 1380) / 2);
    bottom: calc((100vh - clamp(0px, 22.0512820513vw, 120px) - 20px - 86px - var(--height)) / 2);
    border-radius: calc(0.04 * var(--height));
  }
}

body .product .productContentsWrap .productContent .productImg {
  position: absolute;
  z-index: 4;
}

@media (max-width: 899.9px) {
  body .product .productContentsWrap .productContent .productImg {
    width: calc(3.3272058824 * var(--height));
    height: calc(0.9191176471 * var(--height));
  }
}

@media (min-width: 900px) {
  body .product .productContentsWrap .productContent .productImg {
    width: calc(3.62 * var(--height));
    height: calc(1 * var(--height));
    margin-left: calc(-1 * 0.9 * var(--height));
  }
}

body .product .productContentsWrap .productContent .productName {
  color: #003f7e;
  position: relative;
  z-index: 5;
}

@media (max-width: 899.9px) {
  body .product .productContentsWrap .productContent .productName {
    font-size: calc(0.03 * var(--height));
    margin: calc(0.3970588235 * var(--height)) calc(0.0606617647 * var(--height)) 0 calc(0.0606617647 * var(--height));
    /* height: calc(0.0882352941 * var(--height)); */
  }
}

@media (min-width: 900px) {
  body .product .productContentsWrap .productContent .productName {
    font-size: calc(0.08 * var(--height));
    font-weight: 900;
    margin: calc(0.108 * var(--height)) calc(0.192 * var(--height)) 0 calc(1.57 * var(--height));
  }
}

body .product .productContentsWrap .productContent .productText {
  color: #003f7e;
  position: relative;
  z-index: 5;
}

@media (max-width: 899.9px) {
  body .product .productContentsWrap .productContent .productText {
    font-size: calc(0.025 * var(--height));
    margin: calc(0.0220588235 * var(--height)) calc(0.0514705882 * var(--height)) 0 calc(0.0514705882 * var(--height));
    /* height: calc(0.3235294118 * var(--height)); */
  }
}

@media (min-width: 900px) {
  body .product .productContentsWrap .productContent .productText {
    font-size: calc(0.032 * var(--height));
    margin: calc(0.048 * var(--height)) calc(0.192 * var(--height)) 0 calc(1.57 * var(--height));
  }
}

body .product .productContentsWrap .productContent .productButton {
  background-color: #003f7e;
  color: #ffffff;
  text-align: center;
  position: relative;
  z-index: 5;
}

@media (max-width: 899.9px) {
  body .product .productContentsWrap .productContent .productButton {
    font-size: calc(0.025 * var(--height));
    margin: calc(0.0294117647 * var(--height)) auto 0 calc(0.0514705882 * var(--height));
    width: calc(0.2941176471 * var(--height));
    height: calc(0.0735294118 * var(--height));
    line-height: calc(0.0735294118 * var(--height));
    border-radius: calc((0.0735294118 * var(--height)) / 2);
  }
}

@media (min-width: 900px) {
  body .product .productContentsWrap .productContent .productButton {
    margin: calc(0.048 * var(--height)) calc(0.192 * var(--height)) 0 calc(1.57 * var(--height));
    font-size: calc(0.032 * var(--height));
    width: 300px;
    line-height: calc(0.112 * var(--height));
    border-radius: calc((0.112 * var(--height)) / 2);
  }
}

body .product .productContentsWrap .minusIndex {
  display: none;
}

body .column {
  margin-top: 40px;
}

body .column .columnContentsWrap {
  overflow-x: hidden;
  overflow-y: visible;
  --width: clamp(240px, 18vw, 18vw);
  scrollbar-width: none;
}

body .column .columnContentsWrap .swiper {
  --margin: clamp(10px, 1.67vw, 1.67vw);
  --width: clamp(240px, 18vw, 18vw);
  width: calc(var(--width) * 5 + var(--margin) * 10);
}

body .column .columnContentsWrap .columnContents {
  --width: clamp(240px, 18vw, 18vw);
  width: var(--width);
  height: calc(var(--width) / 240 * 304);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  position: relative;
  width: 95%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function,
      initial);
  box-sizing: content-box;
  scrollbar-width: none;
}

body .column .columnContentsWrap .columnContents .columnContent {
  --width: calc(100%);
  width: var(--width);
  margin: 0 auto;
  scroll-snap-align: start;
  flex-shrink: 0;
  width: 360px;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
  padding-left: 5%;
}

body .column .columnContentsWrap .swiper .columnContents .columnContent img {
  background-color: azure;
  width: 100%;
  object-fit: cover;
  aspect-ratio: 240/148;
}

body .column .columnContentsWrap .swiper .columnContents .columnContent .columnText {
  --contentWidth: calc(clamp(240px, 18vw, 18vw) + 2 * clamp(10px, 1.67vw, 1.67vw));
  padding: calc(var(--contentWidth) * 0.02) calc(var(--contentWidth) * 0.044);
  font-size: clamp(16px, calc(var(--contentWidth) * 0.05), 20px);
}

body .column .columnContentsWrap .swiper .columnContents .columnContent .columnText span {
  font-size: clamp(10px, calc(var(--contentWidth) * 0.046), 16px);
}

.columnImg {
  border-radius: 10px;
  height: 215px;
  object-fit: cover;
}

.columnContent .colmunTitle {
  padding: 10px;
  font-size: 15px;
}

body .footer {
  position: relative;
  z-index: 1;
  color: #ffffff;
  letter-spacing: 0.06em;
}

body .footer .footerBg {
  position: absolute;
  width: 100%;
  z-index: 2;
}

@media (max-width: 899.9px) {
  body .footer .footerBg {
    display: none;
  }
}

body .footer .footerBgSp {
  position: absolute;
  width: 100%;
  z-index: 2;
}

@media (min-width: 900px) {
  body .footer .footerBgSp {
    display: none;
  }
}

@media (max-width: 899.9px) {
  body .footer {
    padding-bottom: 3.3333333333vw;
    margin-top: 12.8205128205vw;
  }
}

@media (min-width: 900px) {
  body .footer {
    padding-bottom: 1.3888888889vw;
    margin-top: 12.8205128205vw;
  }
}

body .footer .footerContentsWrap {
  position: relative;
  z-index: 3;
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap {
    padding-top: 15.641025641vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap {
    padding: 8vw 0;
    display: flex;
    justify-content: center;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerLogo {
    width: 30%;
    margin: 0 auto;
    display: block;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerLogo {
    margin-left: 5.5555555556vw;
    width: 20%;
    height: 100%;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents {
    margin-left: 5.5555555556vw;
    width: 40%;
    height: 27.5895833333vw;
  }
}

body .footer .footerContentsWrap .footerContents .footerFlex {
  display: flex;
  justify-content: space-between;
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex {
    width: 91.7948717949vw;
    height: 14.358974359vw;
    margin: 5.641025641vw auto 7.4358974359vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex {
    width: 30vw;
    height: 4.0277777778vw;
  }
}

body .footer .footerContentsWrap .footerContents .footerFlex .blueButton {
  background-color: #ffffff;
  color: #003f7e;
  text-align: center;
  font-family: 'Times New Roman', sans-serif;
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex .blueButton {
    width: 44.358974359vw;
    line-height: 14.358974359vw;
    border-radius: 7.1794871795vw;
    font-size: 4.1025641026vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex .blueButton {
    width: 14.4444444444vw;
    line-height: 4.0277777778vw;
    border-radius: 2.0138888889vw;
    font-size: 1.1111111111vw;
  }
}

body .footer .footerContentsWrap .footerContents .footerFlex2 {
  display: flex;
  justify-content: left;
  font-family: "Klee One", sans-serif;
  font-weight: 600;
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 {
    width: 44.6153846154vw;
    height: 9.2307692308vw;
    margin: 0 10% 5%;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 {
    width: 12.0833333333vw;
    height: 2.5201388889vw;
    margin: 2.7777777778vw auto 0;
    margin-left: 10%;
    margin-bottom: 5%;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 .followUs {
    line-height: 9.2307692308vw;
    font-size: 4.1025641026vw;
    white-space: nowrap;
    padding-right: 10%;
    font-family: "Klee One", sans-serif;
    font-weight: 600;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 .followUs {
    line-height: 2.5vw;
    font-size: 1.3888888889vw;
    white-space: nowrap;
    padding-right: 10%;
    font-family: "Klee One", sans-serif;
    font-weight: 600;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 .instaIcon {
    width: 9.2307692308vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex2 .instaIcon {
    width: 2.5vw;
  }
}

body .footer .footerContentsWrap .footerContents .footerFlex3 {
  display: flex;
  justify-content: space-between;
  font-weight: 400;
  font-family: "Klee One", sans-serif;
}

body .footer .footerContentsWrap .footerContents .footerFlex3 .rightMenu {
  font-family: 'Times New Roman', sans-serif;
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 {
    /* margin: 0 12.8205128205vw 12.3076923077vw 4.1025641026vw; */
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 {
    margin: 2.7777777778vw 3.4722222222vw 0 3.5416666667vw;
  }

  body .footer .footerContentsWrap .footerContents .footerFlex3 {
    display: flex;
    justify-content: space-between;
    gap: 15%;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .leftMenu {
    font-size: 4.1025641026vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .leftMenu {
    font-size: 1.3888888889vw;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .leftMenu div {
    margin-bottom: 2.5641025641vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .leftMenu div {
    margin-bottom: 0.8333333333vw;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .rightMenu {
    font-size: 3.0769230769vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .rightMenu {
    font-size: 0.9722222222vw;
  }
}

@media (max-width: 899.9px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .rightMenu div {
    margin-bottom: 1.5384615385vw;
  }
}

@media (min-width: 900px) {
  body .footer .footerContentsWrap .footerContents .footerFlex3 .rightMenu div {
    margin-bottom: 0.5555555556vw;
  }
}

body .footer .copyRight {
  position: relative;
  z-index: 3;
  text-align: center;
}

@media (max-width: 899.9px) {
  body .footer .copyRight {
    height: 5.641025641vw;
    font-size: 3.5897435897vw;
    line-height: 5.641025641vw;
  }
}

@media (min-width: 900px) {
  body .footer .copyRight {
    /* margin-top: 8.3826388889vw; */
    height: 1.5277777778vw;
    font-size: 0.9722222222vw;
    line-height: 1.5277777778vw;
  }
}

img {
  width: 100%;
}

.titleWrap {
  z-index: 10;
  position: relative;
  overflow: hidden;
  height: clamp(0px, 22.0512820513vw, 120px);
}

@media (max-width: 899.9px) {
  .titleWrap {
    margin-top: 8vh;
  }
}

@media (min-width: 900px) {
  .titleWrap {
    margin-top: 4%;
  }
}

.titleWrap .title {
  width: auto;
  position: absolute;
  margin-top: clamp(0px, 4.8717948718vw, 26.5px);
  height: clamp(0px, 12.3076923077vw, 67px);
}

.titleWrap .title1 {
  right: -500px;
}

.titleWrap .title2 {
  left: -500px;
}

.titleWrap .title3 {
  right: -500px;
}

@keyframes border-transform {

  0%,
  100% {
    border-radius: 63% 37% 54% 46%/55% 48% 52% 45%;
  }

  14% {
    border-radius: 40% 60% 54% 46%/49% 60% 40% 51%;
  }

  28% {
    border-radius: 54% 46% 38% 62%/49% 70% 30% 51%;
  }

  42% {
    border-radius: 61% 39% 55% 45%/61% 38% 62% 39%;
  }

  56% {
    border-radius: 61% 39% 67% 33%/70% 50% 50% 30%;
  }

  70% {
    border-radius: 50% 50% 34% 66%/56% 68% 32% 44%;
  }

  84% {
    border-radius: 46% 54% 50% 50%/35% 61% 39% 65%;
  }
}

.menu .menuButton {
  position: fixed;
  top: 0;
  right: 0;
  width: clamp(0px, 18.9743589744vw, 92.5px);
  height: clamp(0px, 18.9743589744vw, 92.5px);
  background-color: rgba(255, 255, 255, 0.5);
  font-size: clamp(0px, 4.1025641026vw, 20px);
  line-height: clamp(0px, 18.9743589744vw, 92.5px);
  text-align: center;
  font-weight: bold;
  z-index: 22;
  transition: all 500ms 1200ms;
}

@media (min-width: 900px) {
  .menu .menuButton {
    display: none;
  }
}

.menu .nav {
  position: fixed;
  top: 0;
  right: 0;
  width: clamp(0px, 18.9743589744vw, 92.5px);
  height: clamp(0px, 18.9743589744vw, 92.5px);
  background-color: rgba(255, 255, 255, 0.7);
  font-size: clamp(0px, 4.1025641026vw, 20px);
  line-height: clamp(0px, 18.9743589744vw, 92.5px);
  text-align: center;
  font-weight: bold;
  z-index: 21;
  box-shadow: 0 8px 30px 0 rgba(0, 0, 0, 0.3);
  animation: border-transform 7s linear infinite;
  opacity: 0;
  transition: top 350ms 1100ms cubic-bezier(0.23, 1, 0.32, 1),
    right 350ms 1100ms cubic-bezier(0.23, 1, 0.32, 1),
    transform 250ms 1100ms ease,
    width 650ms 400ms cubic-bezier(0.23, 1, 0.32, 1),
    height 650ms 400ms cubic-bezier(0.23, 1, 0.32, 1),
    background-color 650ms 400ms cubic-bezier(0.23, 1, 0.32, 1),
    opacity 1000ms 2000ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu .nav .mobileMenuWrap {
  width: 100%;
  height: 100%;
  overflow: scroll;
  transition: all 650ms 1100ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu .nav .mobileMenuWrap .mobileMenu {
  transition: all 650ms 1100ms cubic-bezier(0.23, 1, 0.32, 1);
  width: 100%;
  height: 160.7692307692vw;
  min-height: 100vh;
  background-color: #003f7e;
}

.menu .nav .mobileMenuWrap .mobileMenu .menuFlex {
  height: 18.9743589744vw;
  background-color: #ffffff;
  padding: 0 4.1025641026vw;
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.menu .nav .mobileMenuWrap .mobileMenu .menuFlex .stlassh {
  width: 22.8205128205vw;
  height: 10vw;
}

.menu .nav .mobileMenuWrap .mobileMenu .menuFlex .closeIcon {
  height: 100%;
  margin-top: 10%;
}

.menu .nav .mobileMenuWrap .mobileMenu .menuFlex .closeIcon img {
  width: 8.2051282051vw;
  height: 8.2051282051vw;
}

.menu .nav .mobileMenuWrap .mobileMenu .menuContent {
  height: 14.1025641026vw;
  border-bottom: 0.2564102564vw solid #ffffff;
  line-height: 14.1025641026vw;
  padding-left: 4.1025641026vw;
  color: #ffffff;
}

.menu .nav .mobileMenuWrap .mobileMenu .logInFlex {
  display: flex;
}

.menu .nav .mobileMenuWrap .mobileMenu .logInFlex .logIn {
  width: calc(91.7948717949vw / 2);
  height: 12.3076923077vw;
  background-color: #ffffff;
  margin: 7.1794871795vw calc((100vw - 91.7948717949vw) / 4) 0;
  text-align: center;
  line-height: 12.3076923077vw;
  border-radius: 6.1538461538vw;
  font-weight: bold;
  color: #003f7e;
}

.menu .nav .mobileMenuWrap .mobileMenu .logOut {
  width: 91.7948717949vw;
  height: 12.3076923077vw;
  background-color: #ffffff;
  margin: 7.1794871795vw auto 0;
  text-align: center;
  line-height: 12.3076923077vw;
  border-radius: 6.1538461538vw;
  font-weight: bold;
  color: #003f7e;
}

.menu .menu-icon {
  display: none;
}

.menu .menu-icon:not(:checked)~.nav .mobileMenuWrap {
  opacity: 0;
  transition: all 650ms 400ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu .menu-icon:not(:checked)~.nav .mobileMenuWrap .mobileMenu {
  opacity: 0;
  transition: all 650ms 400ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu .menu-icon:checked~.menuButton {
  background-color: #003f7e;
}

.menu .menu-icon:checked~.nav {
  opacity: 1;
  background-color: #003f7e;
  animation-play-state: paused;
  top: 50%;
  right: 50%;
  transform: translate(50%, -50%);
  width: 100vw;
  height: 100vh;
  transition: top 350ms 700ms cubic-bezier(0.23, 1, 0.32, 1),
    right 350ms 700ms cubic-bezier(0.23, 1, 0.32, 1), transform 250ms 700ms ease,
    width 750ms 1000ms cubic-bezier(0.23, 1, 0.32, 1),
    height 750ms 1000ms cubic-bezier(0.23, 1, 0.32, 1),
    background-color 750ms 700ms cubic-bezier(0.23, 1, 0.32, 1),
    opacity 400ms 0ms cubic-bezier(0.23, 1, 0.32, 1);
}

.menu .menu-icon:checked~.menuButton {
  opacity: 0;
  transition: all 250ms 1000ms;
}

/* 2507 */

.l-header__inner__block__item .count,
.l-header__inner__block__item--menu .count,
.l-header__inner__block__item--search .count {
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 20px;
  height: 20px;
  font-size: 12px;
  position: absolute;
  left: -10px;
  top: -5px;
  padding: 0 4px;
  border-radius: 10px;
}

.l-header__inner__block {
  display: flex;
  position: relative;
  align-items: baseline;
}

.first_view {
  /* max-width: 800px; */
  margin: 0 auto;
}

/* slideshow */
.p-kv_slider__nav {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(100% - 0px);
  left: 50%;
  bottom: 0;
  position: relative;
  padding: 20px;
}

.p-kv_slider__track__list__item__inner {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  position: relative;
  padding-right: 40px;
  padding-left: 40px;
  padding-top: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.1);
  transition: 1.6s ease-out;
}

@media (min-width: 900px) {
  .p-kv_slider__track__list__item__inner {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    position: relative;
    padding-right: 40px;
    padding-left: 40px;
    padding-top: 42%;
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    transform: scale(1.1);
    transition: 1.6s ease-out;
  }
}

.p-kv_slider__track__list__item__inner:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: unset;
}

@media screen and (max-width: 719px) {
  .p-kv_slider__track__list__item__inner:before {
    background: unset;
  }
}

.p-kv_slider__nav__pagination__dot button {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  opacity: 0.4;
  background-color: grey;
}

.p-kv_slider__nav__arrow {
  width: auto;
  height: auto;
  font-size: 24px;
  position: static;
  background: none;
  opacity: 1;
  transform: none;
  display: none;
}

.p-kv_slider__track__list__item .splide__slide {
  max-width: 800px;
  height: 100%;
  margin: 0 auto;
}

.brand_Concept {
  position: relative;
  overflow: hidden;
  padding-bottom: 20%;
  z-index: 1;
}

.feature {
  color: #373737;
  font-family: "Noto Serif JP", serif;
  line-height: 2rem;
  position: relative;
  margin-top: -40%;
  padding-top: 20%;
}

.feature .video-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

.feature .featureContentWrap {
  position: relative;
  z-index: 1;
  max-width: 800px;
  margin: 0 auto;
}

.feature .featureContentWrap .featureText p {
  font-size: clamp(12px, 1.3vw, 15px);
  text-align: center;
  padding-top: 20px;
}

.feature .featureContentWrap .featureText .featureTitle {
  font-size: clamp(24px, 3.5vw, 32px);
  color: #498ccc;
  font-weight: bold;
}

.feature .featureContentWrap .eight_features {
  position: relative;
}

.feature .featureContentWrap .eight_features .eightPoints_base {
  width: 190%;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}

.point p {
  position: static;
  margin-top: 8px;
  font-size: 14px;
  color: #000;
}

.feature .featureContentWrap .eight_contents {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  transform: translate(-50%, -50%);
  animation: rotate 20s linear infinite;
}

.point {
  position: absolute;
  left: 50%;
  top: 50%;
  transform-origin: center;
}

.point1 {
  transform: translate(-50%, -50%) translateY(-160px);
}

.point2 {
  transform: translate(-50%, -50%) translate(116px, -116px);
}

.point3 {
  transform: translate(-50%, -50%) translate(160px, 0px);
}

.point4 {
  transform: translate(-50%, -50%) translate(116px, 116px);
}

.point5 {
  transform: translate(-50%, -50%) translate(0px, 160px);
}

.point6 {
  transform: translate(-50%, -50%) translate(-116px, 116px);
}

.point7 {
  transform: translate(-50%, -50%) translateX(-160px);
}

.point8 {
  transform: translate(-50%, -50%) translate(-116px, -116px);
}

.bubble {
  width: 130px;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: counterRotate 20s linear infinite;
}

.bubble_back {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 0;
}

.bubble p {
  position: relative;
  z-index: 1;
  font-weight: bold;
  margin-top: 0;
}

@keyframes rotate {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes counterRotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(-360deg);
  }
}

@media (min-width: 900px) {
  .bubble {
    width: 135px;
    height: 135px;
  }

  .point1 {
    transform: translate(-50%, -50%) translateY(-170px);
  }

  .point2 {
    transform: translate(-50%, -50%) translate(126px, -126px);
  }

  .point3 {
    transform: translate(-50%, -50%) translate(170px, 0px);
  }

  .point4 {
    transform: translate(-50%, -50%) translate(126px, 126px);
  }

  .point5 {
    transform: translate(-50%, -50%) translate(0px, 170px);
  }

  .point6 {
    transform: translate(-50%, -50%) translate(-126px, 126px);
  }

  .point7 {
    transform: translate(-50%, -50%) translateX(-170px);
  }

  .point8 {
    transform: translate(-50%, -50%) translate(-126px, -126px);
  }
}

.feature .featureContentWrap .feaContents .fea1 {
  display: flex;
  padding: clamp(2rem, 4vw, 3rem) clamp(1.375rem, 3vw, 2rem);
  position: relative;
}

.feature .featureContentWrap .feaContents .fea1 .featureText {
  width: 70%;
  position: relative;
  z-index: 5;
  margin-top: 2rem;
}

.feature .featureContentWrap .feaContents .fea1 .featureText p {
  margin-top: 8%;
}

.feature .featureContentWrap .feaContents .fea1 .featureText .textBackImg .featureTitle {
  z-index: 5;
  position: relative;
  color: #ffffff;
  padding: 11px;
  display: flex;
  position: relative;
  justify-content: center;
  font-size: clamp(22px, 2.8vw, 26px);
  margin-top: 0;
}

.feature .featureContentWrap .feaContents .fea1 .featureText .textBackImg img {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.feature .featureContentWrap .feaContents .fea1 .feaImg {
  position: absolute;
  z-index: 1;
  right: -30%;
  top: -5%;
  width: 90%;
}

.feature .featureContentWrap .feaContents .fea2 {
  display: flex;
  justify-content: right;
  padding: clamp(2rem, 4vw, 3rem) clamp(1.375rem, 3vw, 2rem);
  position: relative;
}

.feature .featureContentWrap .feaContents .fea2 .featureText {
  width: 70%;
  position: relative;
  z-index: 5;
  margin-top: 2rem;
}

.feature .featureContentWrap .feaContents .fea2 .featureText p {
  margin-top: 8%;
}

.feature .featureContentWrap .feaContents .fea2 .featureText .textBackImg .featureTitle {
  z-index: 5;
  position: relative;
  color: #ffffff;
  padding: 11px;
  display: flex;
  position: relative;
  justify-content: center;
  font-size: clamp(22px, 2.8vw, 26px);
  margin-top: 0;
}

.feature .featureContentWrap .feaContents .fea2 .featureText .textBackImg img {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.feature .featureContentWrap .feaContents .fea2 .feaImg {
  position: absolute;
  z-index: 1;
  left: -55%;
  top: -50%;
}

.hadaterasuContents {
  padding-bottom: 10%;
}

.hadaterasuContents p {
  font-size: clamp(22px, 2.8vw, 26px);
  z-index: 5;
  padding: 11px;
  display: flex;
  position: relative;
  justify-content: center;
  color: white;
}

.hadaterasuContents .textBackImg {
  width: 296px;
  margin: 0 auto;
}

.hands {
  display: flex;
  justify-content: right;
  margin-top: 1rem;
}

.hands img {
  width: 85%;
}

.hadaterasuTexts {
  position: relative;
  width: 265px;
  margin: 0 auto;
}

.hadaterasuTexts p {
  display: flex;
  justify-content: center;
  position: relative;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.hadaterasuTexts img {
  position: absolute;
}

.hadaterasuContents .hadaterasuLogo {
  margin: 2rem auto 1rem;
}

.textBackImg {
  position: relative;
}

.textBackImg img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.sectionTitle p {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(40px, 5vw, 48px);
  text-align: center;
  margin: 2rem;
  font-weight: 100;
}

.steps {
  color: #373737;
  font-family: "Roboto", sans-serif;
}

.itemBlock {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 1000px;
  position: relative;
}

.stepBox {
  flex: 0 0 calc((100% - 5px) / 3);
  max-width: calc((100% - 5px) / 3);
  text-align: center;
  margin-bottom: 3rem;
  flex-direction: column;
  display: grid;
  grid-template-rows: 40px 180px 140px 50px;

  @media (max-width: 899.9px) {
    grid-template-rows: 40px 180px 170px 50px;
  }

  place-items: center;
}

.stepContent {
  position: relative;
}

.arrow-line {
  position: absolute;
  top: 31%;
  transform: translateY(-50%);
  z-index: 0;
  width: 100%;

  @media (max-width: 899.9px) {
    top: 15.8%;
  }
}

.arrow-line2 {
  @media (min-width: 900px) {
    display: none;
  }

  @media (max-width: 899.9px) {
    position: absolute;
    top: 31%;
    transform: translateY(-50%);
    z-index: 0;
    width: 100%;
    top: 65%;
  }
}

.arrow-img {
  position: absolute;
  top: 31%;
  transform: translateY(-50%);
  width: 18px;
  height: auto;
  z-index: 10;
}

.arrow-1 {
  left: calc(33.3333% - 10px);

  @media (max-width: 899.9px) {
    top: 15.8%;
  }
}

.arrow-2 {
  left: calc(66.6666% - 10px);

  @media (max-width: 899.9px) {
    top: 15.8%;
  }
}

.arrow-3 {
  left: calc(50%);

  @media (max-width: 899.9px) {
    left: calc(49%);
    top: 65%;
  }
}

.arrow-4 {
  @media (max-width: 899.9px) {
    display: none;
  }
}

.stepTitle {
  padding: 10px 0;
}

.stepNum {
  color: #a39ac9;
  font-size: clamp(14px, 1.5vw, 17px);
}

.stepTitle p {
  font-size: clamp(12px, 1.3vw, 16px);
}

.itemImg {
  height: 126px;
  width: auto;
  margin: 12px auto;
}

.itemName {
  font-size: clamp(13px, 1.1vw, 16px);
  font-weight: 700;
}

.itemName_kana {
  font-size: clamp(10px, 1vw, 12px);
  font-weight: 700;
}

.itemDetails {
  font-size: clamp(10px, 0.9vw, 12px);
  font-weight: 400;
}

.itemDetailsGrid {
  display: grid;
  grid-template-rows: 30px 20px 80px;

  @media (max-width: 899.9px) {
    grid-template-rows: 40px 50px 80px;
  }

  place-items: center;
}

.stepBox a {
  background-color: #313332;
  border-radius: 7px;
  color: #fff;
  padding: 8px 10px;
  margin-top: auto;
  font-size: clamp(11px, 1.2vw, 14px);
  width: fit-content;
  display: block;
  margin: auto auto 0;
  font-weight: 700;
}

.product {
  position: relative;
  overflow: hidden;
}

body .product .productContentsWrap {
  position: relative;
  height: 100%;
  padding: 5% 0;
}

.product .backgroundImgWrap {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}

.product .backgroundImgWrap .backgroundImg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.productList {
  display: flex;
  justify-content: space-evenly;
  position: relative;
  gap: 23px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  width: 95%;
}

.productItem {
  grid-template-rows: 180px 30px 30px 40px 90px;

  @media (max-width: 899.9px) {
    grid-template-rows: 180px 40px 50px 50px 90px;

  }

  display: grid;
  place-items: center;
  padding-left: 5%;
  scroll-snap-align: start;
  text-align: center;
  font-weight: bold;
  margin-bottom: 3rem;
  position: relative;
  flex: 0 0 calc(50% - 12px);
  scroll-snap-align: start;
}

.productItem .productImg {
  height: 150px;
  width: 100%;
  margin: 12px auto;
  position: relative;
}

.productItem .productImg img {
  height: 100%;
  width: auto;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.productButton {
  background-color: #313332;
  border-radius: 7px;
  color: #fff;
  padding: 8px 10px;
  width: 100%;
  margin: auto auto 0;
  padding: 19px 0;
}

.productCat {
  font-size: clamp(11px, 1vw, 14px);
  padding-bottom: 15px;
  font-weight: 400;
  opacity: 0.5;
}

.productName {
  font-size: clamp(14px, 1.1vw, 18px);
  padding-bottom: 15px;
  font-weight: 700;
}

.productPrice {
  font-size: clamp(15px, 1.2vw, 16px);
  padding-bottom: 15px;
}

.c-product_item__actions {
  position: absolute;
  display: flex;
  z-index: 2;
  top: -10px;
  right: -10%;
}

#newProductIcon {
  display: inline-block;
  background: #606060;
  color: white;
  border-radius: 15px;
  padding: 2px 15px;
  margin-top: 15px;
  margin-right: 8px;
  font-size: clamp(12px, 1.3vw, 16px);
}

#campaignIcon {
  display: inline-block;
  background: #ea5a71;
  color: white;
  border-radius: 15px;
  padding: 2px 15px;
  margin-top: 15px;
  margin-right: 8px;
  font-size: clamp(12px, 1.3vw, 16px);
}

.u-color__bg--alert {
  background: #000;
}

.container_scroll {
  position: relative;
  padding-top: 15px;
}

.scrollbar-text {
  display: inline-block;
  position: absolute;
  bottom: 0;
  right: 120px;
  padding: 0px;
  color: #000;
  font-size: 16px;
  font-family: serif;
  line-height: 1;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  white-space: nowrap;
  animation: scroll-horizontal 10s linear infinite;
}

.scrollbar {
  position: absolute;
  right: 0%;
  bottom: 5px;
}

.scrollbar::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100px;
  height: 1px;
  background: #000;
  animation: liner 2.5s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes liner {
  0% {
    transform: scale(0, 1);
    transform-origin: 100% 0;
  }

  30% {
    transform: scale(1, 1);
    transform-origin: 100% 0;
  }

  70% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }

  100% {
    transform: scale(0, 1);
    transform-origin: 0 0;
  }
}

@media (min-width: 900px) {
  .productItem {
    flex: 0 0 calc((100% - 50px) / 3);
    max-width: calc((100% - 50px) / 3);
    scroll-snap-align: start;
    text-align: center;
    border-radius: 8px;
    font-weight: bold;
    margin-bottom: 3rem;
    position: relative;
    padding: 0 5%;
  }

  .feature .featureContentWrap .eight_features .eightPoints_base {
    width: 102%;
  }

  .brand_Concept {
    padding-bottom: 15%;
  }

  .feature {
    margin-top: -38%;
    padding-top: 20%;
  }

  .feature .featureContentWrap .featureText .featureTitle {
    line-height: 2.5rem;
  }

  .feature .featureContentWrap .feaContents .fea1 .feaImg {
    position: absolute;
    z-index: 1;
    right: -20%;
    top: -5%;
    width: 50%;
  }

  .feature .featureContentWrap .feaContents .fea2 .feaImg {
    position: absolute;
    z-index: 1;
    left: -20%;
    top: -50%;
    width: 50%;
  }

  .hadaterasuContents .textBackImg {
    width: 360px;
    margin: 10px auto;
  }

  .hands {
    display: none;
  }

  .feature .featureContentWrap {
    padding: 5% 0;
  }

  .itemBlock {
    display: flex;
    flex-wrap: unset;
    justify-content: center;
    position: relative;
    width: 100%;
    margin: 0 auto;
  }

  .stepBox {
    flex: 340px;
    max-width: 340px;
  }

  .arrow-line {
    top: 31%;
  }


  .arrow-1 {
    left: calc(20% - 10px);
  }

  .arrow-2 {
    left: calc(40% - 10px);
  }

  .arrow-3 {
    left: calc(60% - 10px);
  }

  .arrow-4 {
    left: calc(80% - 10px);
  }

  .c-product_item__actions {
    right: 6%;
  }

  .productButton {
    width: 80%;
  }

  .columnImg {
    height: 172.66px;
  }
}

/* ======================================= */
/* 20250713 ito */

#bg-video {
  -webkit-mask-image: linear-gradient(to bottom,
      rgba(0, 0, 0, 0),
      /* 上端を透明に */
      rgba(0, 0, 0, 1) 20%,
      /* 徐々に不透明へ */
      rgba(0, 0, 0, 1) 80%,
      /* 中央部分を完全表示 */
      rgba(0, 0, 0, 0)
      /* 下端を透明に */
    );
  mask-image: linear-gradient(to bottom,
      rgba(0, 0, 0, 0),
      rgba(0, 0, 0, 1) 20%,
      rgba(0, 0, 0, 1) 80%,
      rgba(0, 0, 0, 0));

  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  height: 100%;
  object-fit: cover;
}

#product-first-two>div>div.productButton {
  padding: 0;
}

#product-first-two>div>div.productButton>a {
  padding: 19px;
  display: block;
}

.c-category_header:before {
  background: rgba(0, 0, 0, 0) !important;
}

#ec_force_product_search>div>div.p-search_menu__container__inner__search.u-color__border--border>div:nth-child(2) {
  display: none;
}

#index-view>div>section.product>div.productContentsWrap>div.container_scroll>div.scrollbar-text>span {
  font-family: "Inter", sans-serif;
}

#index-view>div>section.column>div.columnContentsWrap>div.container_scroll>div.scrollbar-text>span {
  font-family: "Inter", sans-serif;
}

.arrow-line>img {
  max-height: 50px;
}

.arrow-line2>img {
  max-height: 50px;
}

/* ======================================= */

/*# sourceMappingURL=top.css.map */