.js-fadein {
  opacity: 0;
  -webkit-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-duration: 0.8s;
          transition-duration: 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.js-fadein.is-animated {
  opacity: 1;
}

.js-fadein-up {
  opacity: 0;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-duration: 0.8s;
          transition-duration: 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.js-fadein-up.is-animated {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.js-fadein-zoomout {
  overflow: hidden;
}
.js-fadein-zoomout img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  opacity: 0;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transition-duration: 0.8s;
          transition-duration: 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.js-fadein-zoomout.is-animated img {
  -webkit-transform: scale(1);
          transform: scale(1);
  opacity: 1;
}

.feature-c3fit-compression {
  --min: 1.25rem;
  padding-bottom: 80px;
  background-color: #fff;
  color: #000;
}
.feature-c3fit-compression :where(a) {
  text-decoration: none;
}
@media (min-width: 48.0625em) {
  .feature-c3fit-compression {
    padding-bottom: 100px;
  }
}

.pg-title-bar {
  --h: 54px;
  background-color: #1e42ff;
  height: var(--h, 80px);
}
.pg-title-bar:first-of-type {
  --h: 40px;
}
@media (min-width: 48.0625em) {
  .pg-title-bar {
    --h: 80px;
  }
  .pg-title-bar:first-of-type {
    --h: 56px;
  }
}
.pg-title-bar__heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  font-size: clamp(1.125rem, 2.2222222222vw, 2rem);
  color: #fff;
  font-weight: bold;
}
.pg-title-bar__heading svg {
  fill: #fff;
  width: 268px;
  margin: auto;
  padding-top: 1px;
}
@media (min-width: 48.0625em) {
  .pg-title-bar__heading svg {
    width: 446px;
    padding-top: 2px;
  }
}

.pg-introduction {
  background-color: #000;
  color: #fff;
}
.pg-introduction__container {
  padding: 64px 0;
  --minmax: max(calc(var(--content-min-margin, 24) * 1px), calc(var(--content-base-margin, 40) / var(--content-base-width, 1440) * 100vw));
  max-width: var(--content-max-width, 100%);
  margin-left: auto;
  margin-right: auto;
  width: calc(100% - var(--minmax) * 2);
}
@media (min-width: 48.0625em) {
  .pg-introduction__container {
    padding: 100px 0;
  }
}
.pg-introduction__heading {
  text-align: center;
  font-size: clamp(1.25rem, 2.5vw, 2.25rem);
  line-height: 1.2;
  font-weight: bold;
}
.pg-introduction__text {
  text-align: center;
  font-size: clamp(0.875rem, 1.1111111111vw, 1rem);
  line-height: 1.8;
  margin-top: 24px;
}
@media (min-width: 48.0625em) {
  .pg-introduction__text {
    margin-top: 32px;
  }
}

.pg-sections {
  position: relative;
}

.pg-online-store-link {
  position: absolute;
  top: 0;
  right: 0;
  font-size: clamp(1rem, 1.8055555556vw, 1.625rem);
  padding: 12px 20px 0 0;
  color: #fff;
  mix-blend-mode: difference;
  opacity: 0;
  visibility: hidden;
  -webkit-transition-property: opacity, visibility;
  transition-property: opacity, visibility;
  -webkit-transition-duration: 0.4s;
          transition-duration: 0.4s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  z-index: 50;
}
@media (min-width: 48.0625em) {
  .pg-online-store-link {
    padding: 20px 32px 0 0;
  }
}
.pg-online-store-link a {
  text-decoration: underline;
}
.pg-online-store-link a:hover {
  text-decoration: none;
}
.pg-online-store-link.is-fixed-start {
  position: fixed;
  top: 50px;
  opacity: 1;
  visibility: visible;
}
@media (min-width: 48.0625em) {
  .pg-online-store-link.is-fixed-start {
    top: 70px;
  }
}
.pg-online-store-link.is-fixed-end {
  opacity: 0;
  visibility: hidden;
}

@media (max-width: 48em) {
  .pg-section:last-of-type .pg-product-detail__grid {
    padding-bottom: 48px;
  }
}
.pg-product-desc:nth-of-type(2n) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media (min-width: 48.0625em) {
  .pg-product-desc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
}
.pg-product-desc__mv {
  background-color: #000;
}
@media (min-width: 48.0625em) {
  .pg-product-desc__mv {
    width: 50%;
  }
}
.pg-product-desc__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-left: 5.56%;
  padding-right: 5.56%;
}
@media (max-width: 48em) {
  .pg-product-desc__content {
    padding-top: 32px;
    padding-bottom: 64px;
  }
}
@media (min-width: 48.0625em) {
  .pg-product-desc__content {
    width: 50%;
  }
}
.pg-product-desc__title {
  font-size: clamp(1.25rem, 2.2222222222vw, 2rem);
  line-height: 1.4;
  font-weight: bold;
}
.pg-product-desc__text {
  font-size: clamp(0.875rem, 1.0416666667vw, 0.9375rem);
  line-height: 1.8;
}
.pg-product-desc__text:not(:first-child) {
  margin-top: 24px;
}
.pg-product-desc__text > * + * {
  margin-top: 20px;
}
@media (min-width: 48.0625em) {
  .pg-product-desc__text:not(:first-child) {
    margin-top: 40px;
  }
}

.pg-product-detail__grid {
  display: grid;
  padding: 0 0 80px;
  gap: 40px 0;
  direction: rtl;
}
.pg-product-detail__grid > * {
  direction: ltr;
}
@media (min-width: 48.0625em) {
  .pg-product-detail__grid {
    padding: 60px 0 100px;
    grid-template-columns: repeat(auto-fit, minmax(440px, 1fr));
  }
}

.pg-products {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(1rem, 2.2222222222vw, 2rem);
  padding: 0 20px;
}
@media (max-width: 48em) {
  .pg-products {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 80px;
  }
}
@media (min-width: 48.0625em) {
  .pg-products {
    padding: 0 32px;
  }
}

.pg-product {
  -ms-flex-preferred-size: max(180px, 44.4%);
      flex-basis: max(180px, 44.4%);
}
.pg-product__header {
  text-align: center;
}
.pg-product__title {
  font-size: 1.25rem;
  line-height: 1.2;
  font-weight: bold;
}
.pg-product__subtitle {
  font-size: 0.75rem;
}
.pg-product__subtitle:not(:first-child) {
  margin-top: 12px;
}
.pg-product__img:not(:first-child) {
  margin-top: 32px;
}
@media (max-width: 48em) {
  .pg-product__img {
    padding-left: 20px;
    padding-right: 20px;
  }
}
.pg-product__content {
  margin: 32px auto 0;
}
@media (min-width: 48.0625em) {
  .pg-product__content {
    max-width: 220px;
  }
}
.pg-product__credit:not(:first-child) {
  margin-top: 20px;
}
.pg-product__data {
  font-size: 0.8125rem;
}
.pg-product__data span {
  display: inline-block;
}
.pg-product__data small {
  font-size: 0.625rem;
}
.pg-product__data + .pg-buy-button {
  margin-top: 8px;
}
.pg-product__notice {
  margin-top: 20px;
  font-size: 0.6875rem;
}

.pg-buy-button {
  height: 44px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0 20px;
  width: 100%;
  background-color: #000;
  border: 1px solid #000;
  gap: 8px;
  position: relative;
  -webkit-transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}
.pg-buy-button :is(svg, a) {
  -webkit-transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: all 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}
.pg-buy-button svg {
  width: 16px;
  height: 12px;
  fill: #fff;
}
.pg-buy-button a {
  text-decoration: none;
  font-size: 0.875rem;
  color: #fff;
}
.pg-buy-button a::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}
.pg-buy-button.is-coming-soon {
  color: #000;
  background-color: #fff;
}
.pg-buy-button.is-coming-soon svg {
  display: none;
}
.pg-buy-button.is-coming-soon a {
  pointer-events: none;
  display: none;
}
.pg-buy-button.is-coming-soon::after {
  content: attr(data-label);
  line-height: 1;
  font-size: 0.6875rem;
}
@media (min-width: 48.0625em) {
  .pg-buy-button {
    height: 40px;
    max-width: 220px;
  }
  .pg-buy-button:hover {
    background-color: #fff;
  }
  .pg-buy-button:hover svg {
    fill: #000;
  }
  .pg-buy-button:hover a {
    color: #000;
  }
}

.pg-function__items {
  border-top: 1px solid #999;
}
.pg-function__item {
  border-bottom: 1px solid #999;
  padding: 0 20px;
}
.pg-function__item:not(.is-active) .pg-function__title::before {
  -webkit-transform: rotate(0);
          transform: rotate(0);
}
.pg-function__item:not(.is-active) .pg-function__title::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
.pg-function__item:not(.is-active) .pg-function__content {
  height: 0;
}
@media (min-width: 48.0625em) {
  .pg-function__item {
    padding: 0 32px;
  }
  .pg-function__item:hover {
    cursor: pointer;
  }
}
.pg-function__title {
  font-size: clamp(0.9375rem, 1.25vw, 1.125rem);
  font-weight: normal;
  line-height: 1.2;
  height: 64px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
.pg-function__title::before, .pg-function__title::after {
  content: "";
  display: block;
  width: 18px;
  height: 1px;
  background-color: #666;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: -webkit-transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s, -webkit-transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}
.pg-function__title::before {
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
}
.pg-function__title::after {
  -webkit-transform: rotate(225deg);
          transform: rotate(225deg);
}
.pg-function__content {
  height: var(--accordion-h, 0);
  overflow: hidden;
  -webkit-transition: height 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  transition: height 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}
.pg-function__richtext {
  padding-bottom: 60px;
  font-size: 0.875rem;
}
.pg-function__richtext * + * {
  margin-top: 24px;
}
.pg-function__richtext * + :is(picture, img) {
  margin-top: 32px;
}
@media (min-width: 48.0625em) {
  .pg-function__richtext {
    font-size: 0.9375rem;
  }
}

.pg-footer-button {
  --minmax: max(calc(var(--content-min-margin, 24) * 1px), calc(var(--content-base-margin, 40) / var(--content-base-width, 1440) * 100vw));
  max-width: var(--content-max-width, 100%);
  margin-left: auto;
  margin-right: auto;
  width: calc(100% - var(--minmax) * 2);
}

.pg-stroke-button {
  position: relative;
  border: 1px solid #000;
  font-size: 0.9375rem;
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition-property: background-color, color;
  transition-property: background-color, color;
  -webkit-transition-duration: 0.4s;
          transition-duration: 0.4s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.pg-stroke-button a {
  text-decoration: none;
}
.pg-stroke-button a::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}
@media (min-width: 48.0625em) {
  .pg-stroke-button {
    font-size: 1.125rem;
    height: 80px;
  }
  .pg-stroke-button:hover {
    background-color: #000;
    color: #fff;
  }
}/*# sourceMappingURL=index.css.map */