:root {
  --nav-height: 70px;
  --outer: 1440px;
}

@media only screen and (max-width: 1440px) {
  :root {
    --nav-height: 50px;
    --outer: 1024px;
  }
}
@media only screen and (max-width: 1024px) {
  :root {
    --nav-height: 50px;
    --outer: 90%;
  }
}
@media only screen and (max-width: 640px) {
  :root {
    --nav-height: 40px;
  }
}
:root {
  --nav-height: 70px;
  --outer: 1440px;
}

@media only screen and (max-width: 1440px) {
  :root {
    --nav-height: 50px;
    --outer: 1024px;
  }
}
@media only screen and (max-width: 1024px) {
  :root {
    --nav-height: 50px;
    --outer: 90%;
  }
}
@media only screen and (max-width: 640px) {
  :root {
    --nav-height: 40px;
  }
}
body {
  font-size: 1.25vw;
}

[data-scroll-show] {
  transition: opacity 1s, transform 1s;
}
[data-scroll-show].scrollShowActive {
  opacity: 1 !important;
  transform: none !important;
}

:root {
  --show-transform-y: 3vw;
}

@media only screen and (max-width: 1024px) {
  :root {
    --show-transform-y: 10vw;
  }
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 500;
}

.product-kv {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.product-kv img {
  position: absolute;
  top: 0;
  left: 0;
}

.product-badge {
  padding: 5%;
  background: #fdfdfd;
  text-align: center;
}
.product-badge h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  font-weight: normal;
  color: #272b33;
}
.product-badge p {
  letter-spacing: 0.25vw;
  line-height: 175%;
  margin-top: 1.5%;
}
.product-badge .badge {
  display: block;
  width: 60%;
  margin: auto;
  margin-top: 3%;
}

@media only screen and (max-width: 1024px) {
  body {
    font-size: 3.25vw;
  }
  .product-kv.product-kv-facecare {
    padding-top: 138.76953125%;
  }
  .product-kv.product-kv-magicpro {
    padding-top: 131.8359375%;
  }
  .product-kv.product-kv-refreshgun {
    padding-top: 101.171875%;
  }
  .product-kv.product-kv-gunplus {
    padding-top: 99.21875%;
  }
  .product-badge {
    padding: 10% 5%;
    background: #f2f5f6;
  }
  .product-badge h2 {
    font-size: 4vw;
  }
  .product-badge p {
    margin-top: 3%;
  }
  .product-badge .badge {
    width: 100%;
    margin-top: 3%;
  }
}
body {
  letter-spacing: 0.08vw;
}

.product-gunplus-1 {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #f0f3f6;
}
.product-gunplus-1 p.des {
  position: absolute;
  left: 8%;
  bottom: 1.5%;
  font-size: 0.8vw;
  color: #7D7D7D;
  letter-spacing: 0;
}
.product-gunplus-1 .gunplus-gun,
.product-gunplus-1 .gunplus-img {
  width: 30%;
}
.product-gunplus-1 .gunplus-gun {
  position: relative;
  margin-top: -12%;
  padding-right: 3%;
  left: -1.5%;
  transform: translateX(-100vw);
  transition: transform 2s;
}
.product-gunplus-1 .gunplus-gun img {
  animation: floating 2s 2s infinite alternate;
}
.product-gunplus-1 .gunplus-img {
  margin-top: -3%;
  transform: translateX(100vw);
  transition: transform 2s;
}
.product-gunplus-1 article {
  flex: 1 0 0;
  text-align: center;
  opacity: 0;
  transform: translateY(var(--show-transform-y));
}
.product-gunplus-1 article h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  color: #272b33;
  text-align: center;
}
.product-gunplus-1 article .gunplus-flex {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1vw;
  margin-top: 5%;
}
.product-gunplus-1 article .gunplus-flex p {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 9vw;
  height: 9vw;
  border: 1px solid #6c7987;
  line-height: 125%;
  border-radius: 50%;
  -webkit-border-radius: 50%;
}
.en .product-gunplus-1 article .gunplus-flex p {
  font-size: 1.1vw;
}
.jp .product-gunplus-1 article .gunplus-flex p {
  font-size: 1.1vw;
}

.product-gunplus-2 {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #eaeef1;
}
.product-gunplus-2 p.des {
  position: absolute;
  right: 5%;
  bottom: 1.5%;
  font-size: 0.8vw;
  color: #7D7D7D;
  letter-spacing: 0;
}
.product-gunplus-2 > img {
  display: block;
  width: 60%;
  transform: translateX(-100vw);
  transition: transform 2s;
}
.product-gunplus-2 article {
  flex: 1 0 0;
  line-height: 175%;
  letter-spacing: 0.25vw;
  text-align: justify;
  padding: 0 4% 0 1%;
  transform: translateX(100vw);
  transition: transform 2s;
}
.product-gunplus-2 article h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  line-height: 125%;
  text-align: center;
  color: #272b33;
  margin-bottom: 5%;
}
.product-gunplus-2 article p {
  font-size: 1vw;
  line-height: 135%;
  margin-top: 3%;
  text-align: left;
}

.product-gunplus-3 {
  position: relative;
  background: #e4e8ed;
  padding-top: 3%;
}
.product-gunplus-3 p.des {
  position: absolute;
  left: 8%;
  bottom: 1.5%;
  font-size: 0.8vw;
  color: #7D7D7D;
  letter-spacing: 0;
}
.product-gunplus-3 > img {
  display: block;
  width: 55%;
  margin: auto;
  margin-right: 0;
  transform: translateX(100vw);
  transition: transform 2s;
}
.product-gunplus-3 article {
  position: absolute;
  top: 22.5%;
  left: 8%;
  line-height: 175%;
  letter-spacing: 0.25vw;
  transform: translateX(-100vw);
  transition: transform 2s;
}
.product-gunplus-3 article h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  color: #272b33;
}
.product-gunplus-3 article h3 {
  font-size: 1.75vw;
  letter-spacing: 0.25vw;
  margin: 5% 0 1.5% 0;
}
.product-gunplus-3 article > p {
  font-size: 1vw;
  margin-top: 1%;
}
.product-gunplus-3 .gunplus-flex {
  position: absolute;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  top: 56%;
  left: 8%;
  width: 100%;
  transform: translateX(-100vw);
  transition: transform 2s;
}
.product-gunplus-3 .gunplus-flex div {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 13vw;
  height: 13vw;
  font-size: 1.75vw;
  line-height: 150%;
  letter-spacing: 0.1vw;
  margin: 0 1.5%;
  color: #272b33;
  text-align: center;
  white-space: nowrap;
  border-radius: 50%;
  -webkit-border-radius: 50%;
}
.product-gunplus-3 .gunplus-flex div:nth-child(1) {
  background: radial-gradient(#fcff21, #f9d540);
}
.product-gunplus-3 .gunplus-flex div:nth-child(2) {
  background: radial-gradient(#ffba21, #f99a40);
}
.en .product-gunplus-3 .gunplus-flex div {
  font-size: 1.1vw;
  line-height: 125%;
}

.product-gunplus-4 {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row-reverse;
  text-align: center;
}
.product-gunplus-4 p.des {
  position: absolute;
  right: 5%;
  bottom: 1.5%;
  font-size: 0.8vw;
  color: #7D7D7D;
  letter-spacing: 0;
}
.product-gunplus-4 .img-block {
  display: block;
  width: 45%;
}
.product-gunplus-4 article {
  flex: 1 0 0;
  padding: 0 5%;
}
.product-gunplus-4 article h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  line-height: 125%;
  color: #272b33;
}
.product-gunplus-4 article h3 {
  font-size: 1.25vw;
  line-height: 175%;
  letter-spacing: 0.25vw;
  margin-top: 3%;
}
.product-gunplus-4 article .gunplus-flex {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 3vw 0;
  padding: 5% 0;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type {
  position: relative;
  width: 45%;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type.active .img-active {
  opacity: 1;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type img {
  display: block;
  margin: auto;
  width: 65%;
  transition: transform 0.5s, opacity 0.5s;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type .img-active {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type h4 {
  font-size: 2.25vw;
  letter-spacing: 0.5vw;
  color: #272b33;
  margin: 3% 0 5% 0;
}
.product-gunplus-4 article .gunplus-flex .gunplus-type p {
  letter-spacing: 0.25vw;
  line-height: 150%;
}

.product-gunplus-info {
  position: relative;
  background: #eaeef1;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 0 10% calc(12% + 5rem) 10%;
  flex-direction: column;
  height: 65vw;
}
.product-gunplus-info p.des {
  position: absolute;
  left: 0;
  width: 100%;
  text-align: center;
  bottom: 5rem;
  font-size: 0.8vw;
  color: #7D7D7D;
  letter-spacing: 0;
  line-height: 150%;
}
.product-gunplus-info h2 {
  font-size: 2.5vw;
  letter-spacing: 0.5vw;
  color: #272b33;
  opacity: 0;
  transform: translateY(var(--show-transform-y));
}
.product-gunplus-info article {
  letter-spacing: 0.25vw;
  line-height: 175%;
  width: 45%;
  text-align: justify;
  margin-top: 1.5%;
  opacity: 0;
  transform: translateY(var(--show-transform-y));
}
.en .product-gunplus-info article {
  text-align: left;
}
.product-gunplus-info .gunplus-gun-1,
.product-gunplus-info .gunplus-gun-2,
.product-gunplus-info .gunplus-gun-1-w,
.product-gunplus-info .gunplus-gun-2-w {
  position: absolute;
  text-align: center;
  line-height: 150%;
  letter-spacing: 0.25vw;
}
.product-gunplus-info .gunplus-gun-1 {
  width: 27%;
  top: 35%;
  right: 25%;
  animation: floating 2s infinite alternate;
}
.product-gunplus-info .gunplus-gun-2 {
  width: 27%;
  top: 8%;
  right: 7%;
  animation: floating 2.5s -1.5s infinite alternate;
}
.product-gunplus-info .gunplus-gun-1-w {
  top: 75%;
  right: 44%;
}
.product-gunplus-info .gunplus-gun-2-w {
  top: 57%;
  right: 12%;
}
@keyframes floating {
  from {
    transform: translateY(0%);
  }
  to {
    transform: translateY(-10%);
  }
}

@media only screen and (min-width: 1025px) {
  .gunplus-type:hover img {
    transform: scale(1.1);
  }
}
@media only screen and (max-width: 1024px) {
  body {
    letter-spacing: 0.1vw;
  }
  .product-gunplus-1 {
    display: block;
  }
  .product-gunplus-1 p.des {
    left: auto;
    right: 5%;
    font-size: 2vw;
  }
  .product-gunplus-1 .gunplus-gun {
    position: absolute;
    margin-top: 0;
    padding-right: 0;
    left: 30%;
    top: 20%;
    width: 40%;
    opacity: 0;
    transform: translateY(var(--show-transform-y));
    transition: opacity 1s 0.5s, transform 1s 0.5s;
  }
  .product-gunplus-1 .gunplus-img {
    margin-top: 0;
    width: 100%;
    opacity: 0;
    transform: translateY(var(--show-transform-y));
    transition: opacity 1s 0.5s, transform 1s 0.5s;
  }
  .product-gunplus-1 article h2 {
    font-size: 6vw;
  }
  .product-gunplus-1 article .gunplus-flex {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0;
    margin: 5% 0;
  }
  .product-gunplus-1 article .gunplus-flex p {
    width: 25vw;
    height: 25vw;
  }
  .product-gunplus-1 article .gunplus-flex p:nth-child(1), .product-gunplus-1 article .gunplus-flex p:nth-child(7) {
    margin-left: 18%;
    margin-right: 5%;
  }
  .product-gunplus-1 article .gunplus-flex p:nth-child(2), .product-gunplus-1 article .gunplus-flex p:nth-child(8) {
    margin-left: 5%;
    margin-right: 18%;
  }
  .product-gunplus-1 article .gunplus-flex p:nth-child(3), .product-gunplus-1 article .gunplus-flex p:nth-child(5) {
    margin-left: 0;
    margin-right: 23%;
  }
  .product-gunplus-1 article .gunplus-flex p:nth-child(4), .product-gunplus-1 article .gunplus-flex p:nth-child(6) {
    margin-left: 23%;
    margin-right: 0;
  }
  .product-gunplus-1 article .gunplus-flex p:nth-child(5), .product-gunplus-1 article .gunplus-flex p:nth-child(6) {
    margin-top: 3%;
  }
  .en .product-gunplus-1 article .gunplus-flex p {
    font-size: 3vw;
  }
  .jp .product-gunplus-1 article .gunplus-flex p {
    font-size: 3vw;
  }
  .product-gunplus-2 {
    display: block;
    padding-top: 5%;
  }
  .product-gunplus-2 p.des {
    font-size: 2vw;
  }
  .product-gunplus-2 > img {
    width: 100%;
  }
  .product-gunplus-2 article {
    position: absolute;
    top: 8%;
    right: 5%;
    padding: 0;
    width: 53%;
    line-height: 150%;
  }
  .en .product-gunplus-2 article {
    text-align: left;
  }
  .product-gunplus-2 article h2 {
    font-size: 6vw;
  }
  .en .product-gunplus-2 article h2 {
    font-size: 5vw;
  }
  .jp .product-gunplus-2 article h2 {
    font-size: 5vw;
  }
  .product-gunplus-2 article p {
    font-size: 2.5vw;
  }
  .jp .product-gunplus-2 article p {
    letter-spacing: 0;
  }
  .product-gunplus-3 {
    padding-top: 50%;
  }
  .product-gunplus-3 p.des {
    font-size: 2vw;
  }
  .product-gunplus-3 > img {
    width: 80%;
  }
  .product-gunplus-3 article {
    position: absolute;
    top: 5%;
    left: 0;
    right: 0;
    margin: auto;
    width: 95%;
    text-align: center;
    line-height: 175%;
  }
  .product-gunplus-3 article h2 {
    font-size: 6vw;
    line-height: normal;
  }
  .product-gunplus-3 article h3 {
    font-size: 3.25vw;
    margin: 3% 0 0 0;
  }
  .product-gunplus-3 article > p {
    font-size: 2.75vw;
    margin-top: 1%;
  }
  .en .product-gunplus-3 article {
    font-size: 3vw;
  }
  .en .product-gunplus-3 article h3 {
    font-size: 3vw;
  }
  .en .product-gunplus-3 article > p {
    font-size: 2vw;
  }
  .product-gunplus-3 .gunplus-flex {
    top: 48%;
    left: 5%;
    gap: 1.5%;
  }
  .product-gunplus-3 .gunplus-flex div {
    width: 30vw;
    height: 30vw;
    font-size: 3.5vw;
    margin: 0;
  }
  .en .product-gunplus-3 .gunplus-flex div {
    font-size: 2.75vw;
  }
  .product-gunplus-4 {
    display: block;
  }
  .product-gunplus-4 p.des {
    font-size: 2vw;
  }
  .product-gunplus-4 .img-block {
    width: 100%;
  }
  .product-gunplus-4 article {
    flex: 1 0 0;
    margin: 8% 0;
  }
  .product-gunplus-4 article h2 {
    font-size: 6vw;
  }
  .product-gunplus-4 article h3 {
    font-size: 3.5vw;
  }
  .product-gunplus-4 article .gunplus-flex {
    gap: 5vw 0;
    padding: 3% 0;
  }
  .product-gunplus-4 article .gunplus-flex .gunplus-type {
    width: 48%;
  }
  .product-gunplus-4 article .gunplus-flex .gunplus-type img {
    display: block;
    margin: auto;
    width: 50%;
  }
  .product-gunplus-4 article .gunplus-flex .gunplus-type h4 {
    font-size: 5vw;
    margin: 5% 0;
  }
  .product-gunplus-info {
    display: block;
    padding: 12% 0 calc(5% + 5rem) 0;
    height: auto;
  }
  .product-gunplus-info p.des {
    position: static;
    font-size: 2vw;
    margin-top: 10%;
  }
  .product-gunplus-info h2 {
    font-size: 6vw;
    text-align: center;
  }
  .product-gunplus-info article {
    width: 75%;
    margin: auto;
    font-size: 3.5vw;
    margin-top: 20%;
  }
  .product-gunplus-info .gunplus-gun-1,
  .product-gunplus-info .gunplus-gun-2,
  .product-gunplus-info .gunplus-gun-1-w,
  .product-gunplus-info .gunplus-gun-2-w {
    line-height: 150%;
    letter-spacing: 0.25vw;
    margin: auto;
  }
  .product-gunplus-info .gunplus-gun-1 {
    position: relative;
    width: 45%;
    top: 0;
    right: 0;
    margin-left: 14%;
    margin-top: -25%;
  }
  .product-gunplus-info .gunplus-gun-2 {
    position: relative;
    width: 45%;
    top: 0;
    right: 0;
    margin-right: 12%;
    margin-top: 10%;
  }
  .product-gunplus-info .gunplus-gun-1-w {
    top: 60%;
    right: 65%;
  }
  .product-gunplus-info .gunplus-gun-2-w {
    top: 44%;
    right: 10%;
  }
}/*# sourceMappingURL=product-gunplus.css.map */