@charset "UTF-8";

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

article > * + * {
  margin-top: 1em;
}

input,
button,
textarea,
select {
  font: inherit;
}

img:not([alt]) {
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

input,
button,
select,
textarea {
  font: inherit;
  border: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  color: #434343;
  letter-spacing: 0;
  /* フォントのアンチエイリアスを滑らかに表示（主にMac向け） */
  -webkit-font-smoothing: antialiased;
  /* Chrome, Safari（WebKit系） */
  -moz-osx-font-smoothing: grayscale;
  /* Firefox on macOS */
  background-color: #f6f6f6;
}

body:not(.using-mouse) a:focus-visible,
body:not(.using-mouse) button:focus-visible,
body:not(.using-mouse) input:focus-visible,
body:not(.using-mouse) select:focus-visible {
  outline: 2px solid #627a8b;
  outline-offset: 3px;
}

iframe {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

.ie-warning {
  background-color: #ffcc00;
  color: #000;
  padding: 10px 20px;
  text-align: center;
  font-size: 16px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
  -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
          box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.hide-xl2 {
  display: block;
}

.hide-lg {
  display: block;
}

.show-lg {
  display: none;
}

.hide-md {
  display: block;
}

.show-md {
  display: none;
}

.lg-md-only {
  display: none;
}

.md-sm-none {
  display: none;
}

.hide-xl {
  display: block;
}

.hide-sm {
  display: block;
}

.hide-sp {
  display: block;
}

/* ==========================================
    共通パーツ
   ========================================== */

.section-title__en {
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.4;
  text-transform: uppercase;
}

.section-title__ja {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.4;
}

/* ==========================================
    MV
   ========================================== */

.mv {
  position: relative;
  margin-top: 0.9375rem;
  overflow-x: clip;
}

.mv__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: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 3;
  justify-content: space-between;
}

.mv__left {
  margin-top: 2.25rem;
  width: 100%;
}

.mv__title {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.4444444444;
  color: #231815;
  text-align: center;
}

.mv__logo-wrapper {
  margin-top: 0.9375rem;
  width: 15.625rem;
  margin-inline: auto;
}

.mv__logo-img {
  aspect-ratio: 27/19;
}

.mv__img-wrapper {
  width: 100%;
  margin-top: 0.9375rem;
  margin-left: 0.9375rem;
}

.mv__img {
  aspect-ratio: 614/567;
}

.mv__bg-wrapper {
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  z-index: 2;
}

.mv__bg-img {
  height: 37.5rem;
  border-radius: 2.5rem 0 0 2.5rem;
}


/* ==========================================
    Product
   ========================================== */

.product {
  overflow-x: clip;
  padding: 3.75rem 0 1.875rem;
  position: relative;
}

.product__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  z-index: 5;
}

.product__left {
  width: 100%;
  display: contents;
}

.product__title {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}

.product__lead {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin-top: 1.875rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.4;
}

.product__text {
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
  margin-top: 1.25rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.75;
}

.product__text + .product__text {
  margin-top: 0.9375rem;
}

.product__img-wrapper {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-top: 1.875rem;
  position: relative;
  z-index: 0;
}

.product__img {
  aspect-ratio: 525/580;
}

.product__bg-circle {
  position: absolute;
  z-index: 1;
  top: -12.5rem;
  right: -6.25rem;
  width: 100%;
}

/* ==========================================
    Scene
   ========================================== */

.scene {
  padding: 1.875rem 0 1.875rem;
  background-color: #eceff0;
}

.scene__lead {
  margin-top: 1.875rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}

.scene__categories {
  margin-top: 1.875rem;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 3.125rem;
}

.scene__icon-wrapper {
  width: 17.1875rem;
  margin-inline: auto;
}

.scene__icon {
  aspect-ratio: 323/198;
  border-radius: 1.25rem;
}

.scene__text {
  margin-top: 0.4375rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  color: #003676;
  text-align: center;
}

.scene__imgs {
  margin-top: 2.5rem;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 1.25rem;
}

.scene__img-wrapper {
  width: 17.1875rem;
  margin-inline: auto;
  border-radius: 1.25rem;
  overflow: hidden;
}

.scene__img {
  aspect-ratio: 44/46;
}

.scene__effect {
  margin-top: 1.25rem;
}

.scene__effect-title {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.4;
  color: #003676;
  text-align: center;
}

.scene__effect-list {
  margin-top: 0.5rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}

.scene__effect-item {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  color: #003676;
}

/* ==========================================
    Features
   ========================================== */

.features {
  padding: 1.875rem 0 1.875rem;
  position: relative;
  overflow-x: clip;
}

.features__content {
  padding: 1.25rem 0 1.875rem;
  z-index: 1;
  border-radius: 2.5rem 0 0 2.5rem;
  position: relative;
}

.features__content::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  height: 100%;
  background-color: #fff;
  border-radius: 1.875rem 0 0 1.875rem;
  z-index: -1;
}

.features__inner {
  padding-left: 2.5rem;
  padding-right: 1.25rem;
}

.features__list {
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 1.875rem;
}

.features__image-wrapper {
  border-radius: 1.25rem;
  overflow: hidden;
  width: 17.1875rem;
  margin-inline: auto;
}

.features__image {
  aspect-ratio: 1/1;
}

.features__heading {
  margin-top: 0.625rem;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.4;
  color: #003676;
  text-align: center;
}

.features__text {
  margin-top: 0.9375rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4;
  color: #003676;
}

.features__evolution {
  margin-top: 2.5rem;
  padding: 1.875rem 1.25rem;
  border-radius: 1.875rem;
  background-color: #f2f2f2;
}

.features__evolution-title {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.4;
  color: #627a8b;
  letter-spacing: 0.05em;
  text-align: center;
  padding-bottom: 0.9375rem;
  border-bottom: 0.0625rem solid #627a8b;
}

.features__point {
  margin-top: 2.5rem;
  position: relative;
  border-radius: 1.875rem;
  background-color: #fff;
}

.features__point-head {
  position: absolute;
  top: -1.25rem;
  left: -0.625rem;
  width: 4.375rem;
  height: 4.375rem;
  border-radius: 50%;
  background-color: #627a8b;
  text-align: center;
  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: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #fff;
}

.features__point-label {
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-transform: uppercase;
  margin-left: 0.1875rem;
}

.features__point-number {
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1;
}

.features__point-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 1.25rem;
  background-color: #fff;
  border-radius: 1.25rem;
  padding: 3.75rem 1.25rem 1.875rem 1.25rem;
}

.features__point-text {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.5;
  color: #231815;
}

.features__point-text .navy {
  color: #627a8b;
}

.features__point-image {
  aspect-ratio: 28/18;
}

.features__circle {
  position: absolute;
  z-index: 0;
  top: 6.25rem;
  left: -6.25rem;
  width: 100%;
}

/* ==========================================
    Case
   ========================================== */

.case {
  padding: 1.875rem 0 1.875rem;
  overflow-x: clip;
  position: relative;
}

.case__inner {
  position: relative;
  z-index: 1;
}

.case__slider {
  margin-top: 1.875rem;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.case__slider .slick-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.slick-slide {
  margin-left: 1.25rem;
}

.case__item {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
}

.case__item::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(57, 57, 57, 0.5);
  z-index: 2;
}

.case__link {
  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%;
}

.case__img-wrapper {
  width: 100%;
  height: 100%;
  z-index: 1;
}

.case__img {
  aspect-ratio: 1/1;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.case__content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  color: #fff;
  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-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.case__ja,
.case__en {
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.4;
  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-column-gap: 0.625rem;
     -moz-column-gap: 0.625rem;
          column-gap: 0.625rem;
  text-align: center;
  margin-left: 0.625rem;
}

.case__arrow-icon {
  width: 1rem;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.case__en {
  margin-top: 1.875rem;
  margin-left: -0.1875rem;
}

.slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.9375rem;
  list-style: none;
  margin-top: 1.875rem;
  padding: 0;
}

.slick-dots li {
  width: 2.5rem;
  height: 0.1875rem;
  background-color: #ddd;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  cursor: pointer;
}

.slick-dots li button {
  display: none;
}

.slick-dots li.slick-active {
  background-color: #003676;
}

.case__circle {
  position: absolute;
  z-index: 0;
  top: 4.375rem;
  right: -6.25rem;
  width: 100%;
}

/* ==========================================
    CTA1
   ========================================== */

.cta {
  padding: 0.9375rem 0 1.875rem;
  position: relative;
}

.cta__inner {
  position: relative;
  z-index: 1;
}

.cta__list {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 1.25rem;
}

.cta__link {
  display: block;
  position: relative;
  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: 1.125rem;
  border-radius: 6.25rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
  border: 1px solid transparent;
  -webkit-transition: background-color 0.3s, border-color 0.3s, color 0.3s;
  transition: background-color 0.3s, border-color 0.3s, color 0.3s;
}

.cta__link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 0.5rem;
  height: 0.9375rem;
  background-color: #fff;
  mask-image: url("../img/common/button_icon.webp");
  mask-repeat: no-repeat;
  mask-size: contain;
  mask-position: center;
  -webkit-mask-image: url("../img/common/button_icon.webp");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  -webkit-mask-position: center;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}

.cta__link--trial {
  background-color: #003676;
}

.cta__icon {
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 0.5rem;
}

.cta__link--request {
  background-color: #e68c33;
}

/* ==========================================
    How to Use
   ========================================== */

.how-to-use {
  padding: 1.875rem 0 1.875rem;
}

.how-to-use__inner {
  position: relative;
  z-index: 1;
}

.how-to-use__steps {
  margin-top: 2.5rem;
}

.how-to-use__list {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 3.125rem;
}

.how-to-use__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 0.625rem;
}

.how-to-use__image-wrapper {
  width: 90%;
  margin-inline: auto;
  border-radius: 1.25rem;
  overflow: hidden;
}

.how-to-use__image {
  aspect-ratio: 32/28;
}

.how-to-use__body {
  width: 90%;
  margin-inline: auto;
}

.how-to-use__step-label {
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #627a8b;
}

.how-to-use__step-label .large {
  font-size: 2.25rem;
  letter-spacing: 0.769em;
  line-height: 1;
  color: #627a8b;
  position: relative;
  left: -0.125rem;
  top: 0.125rem;
}

.how-to-use__text {
  margin-top: 0.625rem;
  font-size: 1rem;
  letter-spacing: 0.125em;
  line-height: 1.4;
  color: #231815;
}

.how-to-use__note {
  margin-top: 1.875rem;
  font-size: 1rem;
  letter-spacing: 0.125em;
  line-height: 1.4;
  color: #231815;
}

.how-to-use__video-block {
  margin-top: 1.875rem;
}

.how-to-use__video-wrapper iframe {
  width: 100%;
  aspect-ratio: 16/9;
}

/* ==========================================
    How to Choose
   ========================================== */

.how-to-choose {
  padding: 1.875rem 0 1.875rem;
  background-color: #627a8b;
}

.how-to-choose__title {
  color: #fff;
}

.how-to-choose__intro {
  margin-top: 1.875rem;
  width: 90%;
  margin-inline: auto;
}

.how-to-choose__note {
  margin-top: 1.25rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
}

.how-to-choose__content {
  margin-top: 1.875rem;
  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: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 1.875rem;
  width: 90%;
  margin-inline: auto;
}

.how-to-choose__diagram {
  aspect-ratio: 344/333;
}

.how-to-choose__table-wrapper {
  border-collapse: collapse;
}

.how-to-choose__table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  color: #627a8b;
  border-radius: 0.625rem 0.625rem 0 0;
  overflow: hidden;
}

.how-to-choose__thead .how-to-choose__th {
  padding: 0.703125rem 1.4375rem;
  border-bottom: 0.0625rem solid #fff;
  background-color: #fff;
  vertical-align: middle;
}

.how-to-choose__thead .how-to-choose__th:first-child {
  border-right: 0.0625rem solid #627a8b;
  width: 8.125rem;
  border-radius: 0.625rem 0 0 0;
}

.how-to-choose__thead .how-to-choose__th:last-child {
  width: 16.25rem;
  border-radius: 0 0.625rem 0 0;
}

.how-to-choose__tbody .how-to-choose__th,
.how-to-choose__tbody .how-to-choose__td {
  padding: 0.625rem 1.5625rem;
  border-top: none;
  border-right: 0.0625rem solid #fff;
  border-left: 0.0625rem solid #fff;
  border-bottom: 0.0625rem solid #fff;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  color: #fff;
  background-color: transparent;
  vertical-align: middle;
}

.safari .how-to-choose__tbody .how-to-choose__td {
  border-right: 0.0625rem solid #fff;
}

.how-to-choose__footnote {
  margin-top: 0.625rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  color: #fff;
}

/* ==========================================
    Specifications
   ========================================== */

.specifications {
  margin-top: 3.75rem;
  padding: 1.875rem 0 1.875rem;
  background-color: #627a8b;
}

.specifications__title {
  color: #fff;
}

.specifications__table-wrapper {
  margin-top: 1.875rem;
}

.specifications__table {
  width: 100%;
  border-collapse: collapse;
  color: #fff;
  font-size: 1rem;
  line-height: 1.4;
  border-top: 0.0625rem solid #fff;
}
.specifications__table p {
  text-align: left;
}

.specifications__row {
  border-bottom: 0.0625rem solid #fff;
}

.specifications__head {
  width: 35%;
  padding: 0.625rem 0.9375rem 0.625rem 0.3125rem;
  border-right: 0.0625rem solid #fff;
  font-weight: 700;
  text-align: left;
  vertical-align: top;
}

.safari .specifications__table {
  border-top: none;
}

.safari .specifications__row:first-child {
  border-top: 0.0625rem solid #fff;
}

.specifications__data {
  width: 65%;
  padding: 0.625rem 0.75rem 0.625rem 0.9375rem;
  text-align: left;
  font-weight: 500;
}

.specifications__note {
  font-size: 0.9375rem;
  padding-left: 1em;
  text-indent: -1em;
}

/* ==========================================
    FAQ
   ========================================== */

.faq {
  padding: 1.875rem 0 3.75rem;
}

.faq__list {
  margin-top: 1.875rem;
}

.faq__item + .faq__item {
  margin-top: 1.875rem;
}

.faq__question {
  position: relative;
  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: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  text-align: left;
}

.faq__answer {
  overflow: hidden;
  -webkit-transition: height 0.3s ease;
  transition: height 0.3s ease;
}

.faq__answer.is-closed {
  height: 0 !important;
  overflow: hidden;
}

.faq__num {
  background-color: #627a8b;
  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;
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: 0.114em;
  line-height: 1.4;
  color: #fff;
  width: 100%;
  height: 2.5rem;
  padding-bottom: 0.25rem;
  border-radius: 0.625rem 0.625rem 0 0;
}

.faq__txt {
  background-color: #fff;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.4;
  color: #627a8b;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  padding: 0.9375rem 2.8125rem 0.9375rem 0.9375rem;
  position: relative;
  border-radius: 0 0 0.625rem 0.625rem;
}

.faq__txt::before,
.faq__txt::after {
  position: absolute;
  content: "";
  display: block;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 0.75rem;
  width: 1.25rem;
  height: 0.125rem;
  background-color: #627a8b;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.faq__txt::after {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}

.faq__question.is-open .faq__txt::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.faq__answer-text {
  padding-top: 0.9375rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  padding: 0.625rem;
}

.faq__answer-text--small {
  font-size: 1rem;
}

.faq__link {
  color: #434343;
  text-decoration: underline;
}

/*========================================
  スタッガーアニメーション（.js-stagger）
========================================*/

.js-stagger li {
  opacity: 0;
  -webkit-transform: translateY(15px);
          transform: translateY(15px);
  -webkit-transition: opacity 1.4s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 1.4s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1.4s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 1.4s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1.4s cubic-bezier(0.19, 1, 0.22, 1), transform 1.4s cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1.4s cubic-bezier(0.19, 1, 0.22, 1), transform 1.4s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 1.4s cubic-bezier(0.19, 1, 0.22, 1);
}

.js-stagger li.is-visible {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

@media screen and (min-width: 414px) {
  .hide-sp {
    display: none;
  }
}

@media screen and (min-width: 524px) {
  .md-sm-none {
    display: block;
  }

  .hide-sm {
    display: none;
  }

  .mv__img-wrapper {
    max-width: 520px;
  }

  .slick-slide {
    margin-left: 0.625rem;
  }
}

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }

  .hide-md {
    display: none;
  }

  .show-md {
    display: block;
  }

  .lg-md-only {
    display: block;
  }

  .md-sm-none {
    display: none;
  }

  .section-title__en {
    font-size: 2.5rem;
    line-height: 1.45;
  }

  .section-title__ja {
    margin-top: 0.0625rem;
    font-size: 1.125rem;
    line-height: 1.4444444444;
  }

  .mv {
    margin-top: 1.375rem;
  }

  .mv__content {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-column-gap: 2.8125rem;
       -moz-column-gap: 2.8125rem;
            column-gap: 2.8125rem;
    padding-left: 13.9375rem;
    padding-right: 1.75rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }

  .mv__left {
    margin-top: 0;
    width: 16.875rem;
  }

  .mv__title {
    font-size: 1.5rem;
    line-height: 1.5833333333;
  }

  .mv__logo-wrapper {
    margin-top: 1.375rem;
    width: 16.875rem;
  }

  .mv__img-wrapper {
    max-width: initial;
    width: 42.6388888889vw;
    margin-top: 0.5625rem;
    margin-left: 0;
  }

  .mv__bg-wrapper {
    top: 0;
    width: 100%;
    max-width: 90.9722222222vw;
  }

  .mv__bg-img {
    height: 41.6666666667vw;
    border-radius: 2.5rem 0 0 2.5rem;
  }

  .product {
    padding: 5.875rem 0 7.5625rem;
  }

  .product__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    /*-webkit-column-gap: 3.75rem;
       -moz-column-gap: 3.75rem;
            column-gap: 3.75rem;*/
    align-items: center;
  }

  .product__left {
    display: block;
    margin-top: 1rem;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-left: 1.875rem;
  }

  .product__title {
    -webkit-box-ordinal-group: initial;
        -ms-flex-order: initial;
            order: initial;
  }

  .product__lead {
    -webkit-box-ordinal-group: initial;
        -ms-flex-order: initial;
            order: initial;
    margin-top: 2.4375rem;
    font-size: 2.5rem;
    line-height: 1.45;
  }

  .product__text {
    -webkit-box-ordinal-group: initial;
        -ms-flex-order: initial;
            order: initial;
    margin-top: 1.75rem;
    font-size: 0.9375rem;
    line-height: 2.3333333333;
  }

  .product__text + .product__text {
    margin-top: 2.1875rem;
  }

  .product__img-wrapper {
    margin-top: 0;
    -webkit-box-ordinal-group: initial;
        -ms-flex-order: initial;
            order: initial;
    width: 32.8125rem;
  }

  .product__bg-circle {
    top: -55.875rem;
    right: -19.875rem;
    width: 90.8333333333%;
    max-width: 81.75rem;
  }

  .scene {
    padding: 6.8125rem 0 8.4375rem;
  }

  .scene__lead {
    -webkit-box-ordinal-group: initial;
        -ms-flex-order: initial;
            order: initial;
    margin-top: 2.5rem;
    font-size: 2.5rem;
    line-height: 1.45;
  }

  .scene__categories {
    margin-top: 3.125rem;
    width: 67.75rem;
    margin-inline: auto;
    grid-template-columns: repeat(3, 1fr);
    -webkit-column-gap: 3.5rem;
       -moz-column-gap: 3.5rem;
            column-gap: 3.5rem;
  }

  .scene__icon-wrapper {
    width: 100%;
  }

  .scene__text {
    margin-top: 0.625rem;
    font-size: 0.9375rem;
    line-height: 1.6;
  }

  .scene__imgs {
    margin-top: 5rem;
    width: 57.5rem;
    margin-inline: auto;
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 2.5rem;
       -moz-column-gap: 2.5rem;
            column-gap: 2.5rem;
  }

  .scene__img-wrapper {
    width: 100%;
  }

  .scene__effect {
    margin-top: 2.3125rem;
  }

  .scene__effect-title {
    font-size: 1.5625rem;
    line-height: 1.44;
  }

  .scene__effect-list {
    margin-top: 0.625rem;
  }

  .scene__effect-item {
    font-size: 0.9375rem;
    line-height: 1.6;
    text-align: left;
  }

  .features {
    padding: 7.5rem 0 3.75rem;
  }

  .features__content {
    padding: 7rem 15rem 8.125rem 6.875rem;
    border-radius: 5rem 0 0 5rem;
    padding-inline: 0;
  }

  .features__content::before {
    width: 90.9722222222vw;
    border-radius: 5rem 0 0 5rem;
  }

  .features__inner {
    max-width: 60rem;
    margin-inline: auto;
  }

  .features__list {
    margin-top: 2.5rem;
    grid-template-columns: repeat(4, 1fr);
    -webkit-column-gap: 1.5625rem;
       -moz-column-gap: 1.5625rem;
            column-gap: 1.5625rem;
  }

  .features__image-wrapper {
    width: 11.875rem;
    margin-inline: auto;
  }

  .features__heading {
    margin-top: 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
  }

  .features__text {
    margin-top: 0.875rem;
    font-size: 0.875rem;
    line-height: 1.5714285714;
  }

  .features__evolution {
    margin-top: 6.1875rem;
    padding: 4.3625rem 3.75rem 3.99375rem;
  }

  .features__evolution-title {
    font-size: 1.875rem;
    letter-spacing: 0.111em;
    padding-bottom: 1.51875rem;
  }

  .features__point {
    margin-top: 4.875rem;
  }

  .features__point-head {
    top: -2.375rem;
    left: -1.125rem;
    width: 5.65625rem;
    height: 5.65625rem;
  }

  .features__point-label {
    font-size: 0.9375rem;
    letter-spacing: 0.166em;
    line-height: 1.4;
  }

  .features__point-number {
    margin-top: -0.125rem;
    font-size: 2.5rem;
  }

  .features__point-body {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 0.775rem;
       -moz-column-gap: 0.775rem;
            column-gap: 0.775rem;
    border-radius: 1.875rem;
    padding: 1.875rem 2.5rem 1.875rem 3.8125rem;
  }

  .features__point-text {
    width: 25.4375rem;
    font-size: 1.125rem;
    letter-spacing: 0.2em;
    line-height: 1.6666666667;
  }

  .features__point-image-wrapper {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }

  .features__circle {
    top: 9.375rem;
    left: -16.75rem;
    width: 90.8333333333%;
    max-width: 81.75rem;
  }

  .case {
    padding: 3.75rem 0 3.75rem;
  }

  .case__slider {
    margin-top: 2.53125rem;
    margin-right: calc(50% - 50vw);
    margin-left: -1.75rem;
    position: relative;
  }

  .case__slider .slick-track {
    margin-left: -0.5rem;
  }

  .slick-slide {
    margin-left: 2.71875rem;
  }

  .case__item {
    border-radius: 1.875rem;
  }

  .case__ja,
  .case__en {
    font-size: 1.2rem;
    line-height: 1.3214285714;
    -webkit-column-gap: 0.75rem;
       -moz-column-gap: 0.75rem;
            column-gap: 0.75rem;
    margin-left: 1.375rem;
  }

  .case__ja {
    margin-top: -0.8125rem;
  }

  .case__arrow-icon {
    width: 1.5rem;
  }

  .case__en {
    margin-top: 2.0625rem;
    margin-left: -1.0625rem;
  }

  .slick-dots {
    position: absolute;
    bottom: -2.5rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    margin-top: 3.125rem;
    gap: 1.25rem;
  }

  .slick-dots li {
    width: 3.75rem;
    height: 0.25rem;
  }

  .case__circle {
    top: 6.9375rem;
    right: -19.25rem;
    width: 90.8333333333%;
    max-width: 81.75rem;
  }

  .cta {
    padding: 3.4375rem 0 3.75rem;
  }

  .cta__inner {
    max-width: 960px;
  }

  .cta__list {
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 2.3125rem;
       -moz-column-gap: 2.3125rem;
            column-gap: 2.3125rem;
  }

  .cta__link {
    font-size: 1.25rem;
    line-height: 1.45;
    padding: 1.2875rem 1.25rem 1.3375rem;
  }

  .how-to-use {
    padding: 3.75rem 0 7.5rem;
  }

  .how-to-use__inner {
    max-width: 1220px;
  }

  .how-to-use__steps {
    margin-top: 2.5625rem;
  }

  .how-to-use__list {
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 3.55rem;
       -moz-column-gap: 3.55rem;
            column-gap: 3.55rem;
    row-gap: 1.31875rem;
    padding-right: 3.55rem;
  }

  .how-to-use__item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-column-gap: 1.575rem;
       -moz-column-gap: 1.575rem;
            column-gap: 1.575rem;
  }

  .how-to-use__image-wrapper {
    width: 20rem;
  }

  .how-to-use__body {
    margin-top: 0.375rem;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: 100%;
  }

  .how-to-use__step-label {
    font-size: 1.25rem;
  }

  .how-to-use__step-label .large {
    font-size: 3.25rem;
  }

  .how-to-use__text {
    margin-top: 1rem;
    font-size: 0.9375rem;
    line-height: 1.6;
  }

  .how-to-use__note {
    margin-top: 2.3125rem;
    font-size: 1rem;
    line-height: 1.5;
  }

  .how-to-use__video-block {
    margin-top: 7.5rem;
  }

  .how-to-use__video-wrapper {
    width: 57.5rem;
    margin-inline: auto;
  }

  .how-to-choose {
    padding: 6.875rem 0 8.75rem;
  }

  .how-to-choose__intro {
    margin-top: 2.125rem;
    width: 100%;
    max-width: 920px;
    margin-inline: auto;
  }

  .how-to-choose__note {
    margin-top: 1.75rem;
    font-size: 0.9375rem;
    line-height: 1.8666666667;
  }

  .how-to-choose__content {
    margin-top: 2.3125rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-column-gap: 3.03125rem;
       -moz-column-gap: 3.03125rem;
            column-gap: 3.03125rem;
    width: 48.9375rem;
    margin-inline: auto;
  }

  .how-to-choose__diagram-wrapper {
    width: 21.5rem;
  }

  .how-to-choose__table-wrapper {
    margin-top: 1.8125rem;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }

  .how-to-choose__table {
    font-size: 1.125rem;
    line-height: 1.5;
  }

  .how-to-choose__tbody .how-to-choose__th,
  .how-to-choose__tbody .how-to-choose__td {
    font-size: 1.125rem;
    line-height: 1.5;
  }

  .safari .how-to-choose__tbody .how-to-choose__td {
    border-right: 0.125rem solid #fff;
  }

  .how-to-choose__footnote {
    margin-top: 0.8125rem;
    font-size: 1.125rem;
    line-height: 1.5;
  }

  .specifications {
    margin-top: 7.5rem;
    padding: 6.875rem 0 8.78125rem;
  }

  .specifications__table-wrapper {
    margin-top: 2.5rem;
    max-width: 920px;
    margin-inline: auto;
  }

  .specifications__table {
    font-size: 1.125rem;
    line-height: 1.5;
  }

  .specifications__head {
    width: 13.8125rem;
    padding: 1.1875rem 0.9375rem 1.1875rem 0.3125rem;
  }

  .specifications__data {
    width: calc(100% - 13.8125rem);
    padding: 1.1875rem 2.6875rem 1.1875rem 2.375rem;
  }

  .specifications__note {
    font-size: 1.125rem;
  }

  .faq {
    padding: 7.5rem 0 11.75rem;
  }

  .faq__list {
    margin-top: 4.28125rem;
  }

  .faq__item + .faq__item {
    margin-top: 1.625rem;
  }

  .faq__question {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }

  .faq__num {
    width: 6.875rem;
    height: 6.875rem;
    border-radius: 0.625rem 0 0 0.625rem;
    font-size: 2.1875rem;
    padding-left: 0.3125rem;
  }

  .faq__txt {
    font-size: 1.375rem;
    line-height: 1.4545454545;
    width: calc(100% - 6.875rem);
    height: 6.875rem;
    border-radius: 0 0.625rem 0.625rem 0;
    padding: 1.8125rem;
  }

  .faq__txt::before,
  .faq__txt::after {
    top: 50%;
    right: 1.625rem;
    width: 1.9375rem;
    height: 0.125rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }

  .faq__txt::after {
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
  }

  .faq__question.is-open .faq__txt::after {
    -webkit-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }

  .faq__answer-text {
    padding-top: 1.30625rem;
    font-size: 1.0625rem;
    line-height: 1.8235294118;
    padding-left: 8.6875rem;
    padding-right: 5.875rem;
  }

  .faq__answer-text--small {
    font-size: 0.9375rem;
    line-height: 2.0666666667;
  }
}

@media screen and (min-width: 1024px) {
  .hide-lg {
    display: none;
  }

  .show-lg {
    display: block;
  }

  .lg-md-only {
    display: none;
  }

  .product__inner {
    /*-webkit-column-gap: 9.0625rem;
       -moz-column-gap: 9.0625rem;
            column-gap: 9.0625rem;*/
  }
}

@media screen and (min-width: 1200px) {
  .product__img-wrapper {
    margin-right: 0;
  }

  .features__list {
    -webkit-column-gap: 1.875rem;
       -moz-column-gap: 1.875rem;
            column-gap: 1.875rem;
  }
}

@media (min-width: 1240px) {
  html {
    font-size: 16px;
  }
}

@media screen and (min-width: 1440px) {
  .hide-xl {
    display: none;
  }

  .mv__img-wrapper {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: 100%;
  }

  .mv__bg-img {
    height: 37.5rem;
  }

  .product__left {
    padding-left: 0;
  }

  .features__point-text {
    width: 25.4375rem;
  }
}

@media screen and (min-width: 1601px) {
  .hide-xl2 {
    display: none;
  }

  .mv__bg-wrapper {
    width: calc(18.0555555556vw + 1180px);
  }

  .features__content::before {
    width: calc(18.0555555556vw + 1180px);
  }

  .features__inner {
    max-width: 960px;
  }

  .features__circle {
    max-width: 70.3125vw;
  }
}

@media screen and (min-width: 1920px) {
  .mv__bg-wrapper {
    width: calc(27.0833333333vw + 1180px);
  }

  .features__content::before {
    width: calc(27.0833333333vw + 1180px);
  }

  .slick-dots {
    left: 40%;
  }
}

@media (max-width: 768px) {
  html {
    font-size: min(4.2666666667vw, 24px);
  }
}

@media (min-width: 768px) and (max-width: 1240px) {
  html {
    font-size: 1.2903225806vw;
  }
}

@media screen and (min-width: 768px) and (max-width: 1240px) {
  .features__content::before {
    width: 71.25rem;
  }
}

@media (min-width: 768px) {
  a:hover {
    opacity: 0.7;
  }

  .case__link:hover {
    opacity: 1;
  }

  .case__link:hover .case__arrow-icon {
    -webkit-transform: translateX(0.625rem);
            transform: translateX(0.625rem);
  }

  .case__link:hover .case__img {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }

  .cta__link--trial:hover {
    opacity: unset;
    filter: unset;
    background-color: #fff;
    border-color: #003676;
    color: #003676;
  }

  .cta__link--trial:hover::after {
    background-color: #003676;
  }

  .cta__link--request:hover {
    opacity: unset;
    filter: unset;
    background-color: #fff;
    border-color: #e68c33;
    color: #e68c33;
  }

  .cta__link--request:hover::after {
    background-color: #e68c33;
  }
}

@media screen and (min-width: 768px) {
  .mv__img-wrapper {
    margin-top: auto;
    height: 41.6666666667vw;
  }
}
@media screen and (min-width: 1440px) {
  .mv__img-wrapper {
    height: 37.5rem;
  }
}
@media screen and (max-width: 767px) {
  .mv__content {
    height: 37.5rem;
    overflow: clip;
  }
}
sup {
  vertical-align: super;
  font-size: 0.6em;
}
.faq__answer-text a {
  text-decoration: underline;
}

/* ==========================================
    softpower
   ========================================== */
.softpower .mv__img {
  aspect-ratio: 336 / 600;
  max-width: 13.1rem;
  margin: auto;
}
.softpower .scene__categories {
  margin-top: 1.875rem;
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 3.125rem;
  width: 100%; 
}
.softpower .scene__categories .scene__icon-wrapper {
    border-radius: 20px; 
    overflow: hidden;
}
@media screen and (min-width: 768px) {
  .softpower .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .softpower .mv__content {
    padding-left: 21.9375rem;
  }
  .softpower .scene__categories {
    margin-top: 3.125rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 16.875rem);
    column-gap: 2.19152rem;
    row-gap: 3.125rem;
    justify-content: center;
  }
  .softpower .scene__categories .scene__icon-wrapper {
    width: 16.875rem;
    margin-inline: 0;
    border-radius: 20px;
    overflow: hidden;
  }
}
.softpower .features__list--five-col {
  grid-template-columns: 1fr;
}
.softpower .features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.softpower .features__image {
  max-width: 12rem;
  margin: auto;
}
@media screen and (min-width: 768px) {
  .softpower .features__inner {
    max-width: 60rem;
    margin-inline: auto;
  }
  .softpower .features__list {
    margin-top: 2.5rem;
    grid-template-columns: repeat(4, 1fr);
    -webkit-column-gap: 1.5625rem;
       -moz-column-gap: 1.5625rem;
            column-gap: 1.5625rem;
  }
  .softpower .features__list--five-col {
    grid-template-columns: repeat(5, 1fr);
    -webkit-column-gap: 1.25rem; 
       -moz-column-gap: 1.25rem;
            column-gap: 1.25rem;
  }
  .softpower .features__image-wrapper {
    width: 11.875rem;
    margin-inline: auto;
  }
}
.softpower .mv__logo-img--fix {
  aspect-ratio: auto !important; 
  width: 100%;
  height: auto;
  object-fit: contain;
}
@media screen and (min-width: 768px) {
  .softpower .features__text {
      margin: 0.875rem auto 0;
      width: 9rem;
  }
}
@media screen and (min-width: 1024px) {
  .softpower .product__inner {
      column-gap: 6rem;
  }
}


/* ==========================================
    gsarm
   ========================================== */
.gsarm .mv__logo-img {
  aspect-ratio: 338 / 176;
}
.gsarm .mv__img {
  height: 23rem;
}
.gsarm .mv__title {
  padding-left: 1.8rem;
}
.gsarm .mv__gsarm-layout {
  flex-direction: column-reverse;
}
.gsarm .product__img {
  aspect-ratio: 662 / 392;
}
.gsarm .scene .features__image {
    aspect-ratio: 270 / 380;
}
.gsarm .scene .features__text {
    text-align: center;
}
.gsarm .present-section {
  padding: 1.875rem 0;
}
.gsarm .present-wrapper {
  max-width: 90%;
  margin-inline: auto;
  padding: 1.25rem 0.625rem;
  background-color: #f0f0f0;
  border-radius: 1.25rem;
  text-align: center;
}
.gsarm .present-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: center;
      -ms-flex-align: center;
          align-items: center;
}
.gsarm .present-title__en {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.4;
  text-transform: uppercase;
  color: #434343;
}
.gsarm .present-title__ja {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.4;
  color: #434343;
  margin-top: 0.25rem;
}
.gsarm .present-text-box {
  margin-top: 1.2rem;
  padding: 1.875rem 1.25rem;
  background-color: #fff;
  border-radius: 0.625rem;
  max-width: 100%;
}
.gsarm .present-text {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.8;
  color: #434343;
}
.gsarm .present-text strong {
  font-weight: 700;
}
.gsarm .present-button-wrapper {
  margin-top: 1.5rem;
}
.gsarm .scene {
    padding: 1.875rem 0 3rem;
    background-color: #eceff0;
}
.gsarm .scene .features__list {
    margin-top: 2rem;
    row-gap: 3rem;
}
.gsarm .scene .features__image-wrapper {
  width: 14rem;
}
.gsarm .scene .features__image-wrapper .features__heading {
  margin-top: 0.8rem;
}
.gsarm .scene .features__image-wrapper .features__text {
  margin-top: 0.5rem;
}
.gsarm .features .features__image-wrapper {
  width: 12rem;
}
.gsarm .features .features__heading {
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .gsarm .mv__gsarm-layout {
    padding-left: 2.75rem;
    padding-right: 9rem;
    flex-direction: row;
  }
  .gsarm .mv__gsarm-left {
    width: 22rem;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .gsarm .mv__gsarm-title {
    padding-left: 1.2rem;
  }
  .gsarm .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .gsarm .mv__content {
    column-gap: 0;
  }
  .gsarm .product__img-wrapper {
     width: 38rem;
  }
  .gsarm .features .features__list {
    grid-template-columns: repeat(3, 1fr);
  }
  .gsarm .features .features__text {
    width: 15rem;
    margin: 0.875rem auto 0;
  }
  .gsarm .present-wrapper {
    max-width: 1180px;
    margin: 7rem;
  }
  .gsarm .present-wrapper {
      max-width: 1180px;
      padding: 5rem;
      border-radius: 2.5rem;
      margin: 7rem;
  }
  .gsarm .present-title__en {
    font-size: 2rem;
  }
  .gsarm .present-title__ja {
    font-size: 1.125rem;
  }
  .gsarm .present-text-box {
    margin-top: 2.5rem;
    padding: 3.125rem 0;
    border-radius: 1.25rem;
    width: 100%;
    max-width: 920px;
  }
  .gsarm .present-text {
    font-size: 1.125rem;
    line-height: 2;
    text-align: center;
  }
  .gsarm .present-button-wrapper {
    max-width: 288px;
    margin: 2.5rem auto 0;
  }
  .gsarm .specifications__head {
    width: 15.8125rem;
  }
}


/* ==========================================
    gsback
   ========================================== */
.gsback .mv__img {
    height: 24rem;
}
.gsback .mv__logo-img {
    aspect-ratio: 338 / 176;
}
.gsback .mv__title {
    padding-left: 0.6rem;
}
.gsback .product__img {
    aspect-ratio: 800 / 470;
}
.gsback .product__img {
    aspect-ratio: 1240 / 879;
}
.gsback .features__image {
    max-width: 12rem;
    margin: auto;
}
.gsback .product__lead rt {
    padding-bottom: 0.3rem;
}
@media screen and (min-width: 768px) {
  .gsback .mv__left {
    width: 22.125rem;
  }
  .gsback .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .gsback .mv__title {
    letter-spacing: 0.09em;
    font-size: 1.38rem;
  }
  .gsback .product__img-wrapper {
    width: 39rem;
  }
  .gsback .scene__categories {
    margin-top: 3.125rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 16.875rem);
    column-gap: 2.19152rem;
    row-gap: 3.125rem;
    justify-content: center;
  }
  .gsback .features .features__list {
    grid-template-columns: repeat(5, 1fr);
  }
  .gsback .features__text {
    margin: 0.875rem auto 0;
    max-width: 9.375rem;
  }
  .gsback .specifications__head {
      width: 15.8125rem;
  }
}


/* ==========================================
    softlight
   ========================================== */
.softlight .mv__img {
    aspect-ratio: 614 / 570;
}
.softlight .product__img {
    aspect-ratio: 609 / 379;
}
.softlight .features__image {
    max-width: 12rem;
    margin: auto;
}
.softlight .features__heading {
    margin-top: 0;
}
.softlight .how-to-choose__thead .how-to-choose__th {
  border-right: 0.0625rem solid #627a8b;
}
.softlight .how-to-choose__thead .how-to-choose__th,
.softlight .how-to-choose__tbody .how-to-choose__th {
  padding: 0.703125rem 0rem;
}
.softlight .how-to-choose__thead .how-to-choose__th:nth-child(2) {
    width: 3rem;
}
.softlight .how-to-choose__thead .how-to-choose__th:last-child {
  width: 12.25rem;
}
@media screen and (min-width: 768px) {
  .softlight .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .softlight .product__img-wrapper {
    width: 38.0625rem;
  }
  .softlight .how-to-choose__content {
    width: 54.9375rem;
  }
  .softlight .how-to-choose__table-wrapper {
    margin-top: 0;
  }
  .softlight .how-to-choose__tbody .how-to-choose__th {
    padding: 0.625rem 0.8rem;
  }
  .softlight .how-to-choose__tbody .how-to-choose__td {
    text-align: center;
  }
}


/* ==========================================
    exopower
   ========================================== */
.exopower .mv__title {
    font-size: 1rem;
    letter-spacing: 0.08em;
}
.exopower .mv__img {
    height: auto;
    width: 16.5rem;
    margin: auto;
    aspect-ratio: 1271 / 1580;
}
.exopower .product__img {
    aspect-ratio: 1231 / 863;
}
.exopower .features__image {
  max-width: 12rem;
  margin: auto;
}
.exopower .mv__title sup {
  vertical-align: super;
  font-size: 0.6em;
}
@media screen and (min-width: 768px) {
  .exopower .mv__content {
    flex-direction: row-reverse;
    column-gap: 0;
    padding-left: 11.9375rem;
    padding-right: 9.75rem;
  }
  .exopower .mv__left {
    margin-top: 0;
    width: 18.125rem;
  }
  .exopower .mv__logo-wrapper {
    width: 16.125rem;
  }
  .exopower .mv__title {
    font-size: 1.0625rem;
  }
  .exopower .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .exopower .scene__categories {
    margin-top: 3.125rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 16.875rem);
    column-gap: 2.19152rem;
    row-gap: 3.125rem;
    justify-content: center;
  }
  .exopower .features .features__list {
    grid-template-columns: repeat(3, 1fr);
  }
  .exopower .features__text {
    margin: 0.875rem auto 0;
    max-width: 15rem;
  }
  .exopower .specifications__head {
      width: 15.8125rem;
  }
}


/* ==========================================
    easylift
   ========================================== */
.easylift .mv__img {
    height: 29rem;
    aspect-ratio: 898 / 1200;
}
.easylift .mv__logo-wrapper {
      margin-top: 0;
}
.easylift .mv__logo-img-01 {
    aspect-ratio: 301 / 159;
    width: 18.75rem;
}
.easylift .mv__logo-img-02 {
    aspect-ratio: 364 / 241;
    width: 21rem;
    margin-top: 1.8rem;
}
.easylift .mv__inner {
    position: relative;
}
.easylift .mv__inner .cumulative-total {
    position: absolute;
    bottom: 3rem;
    left: 10rem;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.easylift .cumulative-total-img {
    width: 11rem;
}
.easylift .cumulative-total-note {
    font-size: 0.5625rem;
    color: #9b760d;
    margin: -0.4rem;
}
.easylift .features__image {
    max-width: 12rem;
    margin: auto;
}
.easylift .mv__logo-txt-area {
    margin: 1.8rem auto 1rem;
    width: 18rem;
    padding-left: 1rem;
}
.easylift .mv__logo-txt-area p {
    font-size: 0.875rem;
    font-weight: 700;
    text-align: left;
    letter-spacing: 0;
}
.easylift p.mv__logo-price {
    font-size: 1.25rem;
}
.easylift p.mv__logo-price .tax {
    font-size: 1rem;
}
.easylift .features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .easylift .mv__logo-wrapper {
    width: 24.0625rem;
    margin-top: 0;
    display: flex;
    flex-direction: column;
    row-gap: 1.5rem;
  }
  .easylift .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .easylift .mv__logo-img-02 {
    margin-top: 0.6rem;
  }
  .easylift .mv__logo-txt-area {
    margin: 0;
    width: auto;
    padding-left: 0;
}
  .easylift .mv__logo-txt-area p {
    font-size: 0.875rem;
  }
  .easylift .mv__content {
    flex-direction: row-reverse;
    column-gap: 0;
    padding-left: 12.9375rem;
    padding-right: 10.75rem;
  }
  .easylift .mv__inner .cumulative-total {
    bottom: unset;
    top: 3rem;
    left: 32rem;
  }
  .easylift .scene__categories {
    margin-top: 3.125rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 16.875rem);
    column-gap: 2.19152rem;
    row-gap: 3.125rem;
    justify-content: center;
  }
  .easylift .features .features__list {
    grid-template-columns: repeat(3, 1fr);
  }
  .easylift .features__text {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
    .easylift .mv__content {
        height: 58.5rem;
    }
    .easylift .mv__bg-img {
        height: 58.5rem;
    }
}


/* ==========================================
    harnessplus
   ========================================== */
.harnessplus .mv__img {
    height: 25rem;
    aspect-ratio: 1228 / 1300;
}
.harnessplus .mv__logo-wrapper {
      margin-top: 0;
}
.harnessplus .mv__logo-img-01 {
    aspect-ratio: 237 / 134;
    width: 14.8125rem;
}
.harnessplus .mv__logo-img-02 {
    aspect-ratio: 283 / 273;
    width: 17.6875rem;
    margin-top: 1.8rem;
}
.harnessplus .mv__inner {
    position: relative;
}
.harnessplus .mv__bg-wrapper .cumulative-total {
    position: absolute;
    bottom: 21rem;
    right: 1rem;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.harnessplus .cumulative-total-img {
    width: 9rem;
}
.harnessplus .product__text + .product__text {
    margin-top: 0.9375rem;
    color: #627A8B;
    line-height: 2;
    font-size: 0.75rem;
}
.harnessplus .features__image {
    max-width: 12rem;
    margin: auto;
}
.harnessplus .mv__logo-txt-area {
    margin: 1.8rem auto 1rem;
    width: 19rem;
    padding-left: 1rem;
}
.harnessplus .mv__logo-txt-area p {
    font-size: 0.875rem;
    font-weight: 700;
    text-align: left;
    letter-spacing: 0;
    color: #fff;
}
.harnessplus p.mv__logo-price {
    font-size: 1.25rem;
}
.harnessplus p.mv__logo-price .tax {
    font-size: 1rem;
}
.harnessplus .features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.harnessplus .how-to-use__text.small {
    font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .harnessplus .mv__logo-wrapper {
    width: 24.0625rem;
    margin-top: 0;
    display: flex;
    flex-direction: column;
    row-gap: 1.5rem;
    align-items: center;
  }
  .harnessplus .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .harnessplus .mv__logo-img-02 {
    margin-top: 0;
  }
  .harnessplus .mv__logo-txt-area {
    margin: 0;
    width: auto;
    padding-left: 0;
}
  .harnessplus .mv__logo-txt-area p {
    font-size: 0.875rem;
  }
  .harnessplus .mv__content {
    flex-direction: row-reverse;
    column-gap: 0;
    padding-left: 12.9375rem;
    padding-right: 10.75rem;
  }
  .harnessplus .cumulative-total-img {
    width: 11rem;
  }
  .harnessplus .mv__bg-wrapper .cumulative-total {
    bottom: 1.5rem;
    right: unset;
    left: 1.3rem;
  }
  .harnessplus .features .features__list {
    grid-template-columns: repeat(3, 1fr);
  }
  .harnessplus .features__text {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
    .harnessplus .mv__content {
        height: 58.5rem;
    }
    .harnessplus .mv__bg-img {
        height: 58.5rem;
    }
}


/* ==========================================
    every
   ========================================== */
.every .mv__img {
    aspect-ratio: 952 / 1200;
    width: 19rem;
    margin: auto;
}
.every .mv__title {
    padding-left: 1.5rem;
    color: #124F8B;
}
.every .mv__logo-wrapper {
    width: 10rem;
}
.every .mv__logo-img {
    aspect-ratio: 564 / 480;
}
.every .mv__img-wrapper {
    margin-top: 0;
}
.every .product__img {
    aspect-ratio: 750 / 583;
}
.every .features__item {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.every .features__heading {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1em;
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.4;
    color: #339FE6;
    text-align: center;
    background-color: #F2F2F2;
    border-radius: 1.6875rem;
    width: 100%;
    height: 3.375rem;
}
.every .features__image {
    aspect-ratio: 490 / 407;
    max-width: 12rem;
    margin: auto;
}
.every .features__text {
    font-weight: 700;
}
.every .how-to-use .section-title__en,
.every .how-to-use .section-title__ja {
  text-align: center;
}
.every .how-to-use .how-to-use__video-block {
  margin-top: 1rem;
}
.every .how-to-use__video-block.video01 {
  margin-bottom: 3rem;
}
.every .present-section {
  padding: 1.875rem 0;
}
.every .present-wrapper {
  width: 100%;
  margin-inline: auto;
  padding: 1.25rem 0.625rem;
  background-color: #f0f0f0;
  border-radius: 1.25rem;
  text-align: center;
}
.every .present-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: center;
      -ms-flex-align: center;
          align-items: center;
}
.every .present-title__en {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.4;
  text-transform: uppercase;
  color: #434343;
}
.every .present-title__ja {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.4;
  color: #434343;
  margin-top: 0.25rem;
}
.every .present-text-box {
  margin-top: 1.2rem;
  background-color: #fff;
  border-radius: 0.625rem;
  max-width: 100%;
}
.every .present-text {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.8;
  color: #434343;
}
.every .present-text strong {
  font-weight: 700;
}
.every .present-button-wrapper {
  margin-top: 1.5rem;
}
.every .present-text-lead {
  color: #003676;
  font-size: 1.25rem;
  font-weight: 700;
  margin: 1.875rem auto 1rem;
}
.every .present-text-info,
.every .present-text-info a {
  color: #003676;
  font-size: 1.125rem;
  font-weight: 500;
  margin: 2rem auto 2rem;
}
.every .present-text-info {
  text-align: center;
}
.every .present-text-cap {
  font-size: 0.75rem;
}
.every .present-text-info a,
.every .present-text-cap a {
  text-decoration: underline;
}
.every .present-section .form-area {
  margin: 2rem auto;
}
.every .present-section iframe {
  height: 74rem;
}
.every .present-text-lead,
.every .present-text,
.every .present-text-info,
.every .present-text-cap-area {
  padding: 0 1.25rem;
}
@media screen and (min-width: 768px) {
  .every .mv__content {
    flex-direction: row-reverse;
    column-gap: 0;
    padding-left: 13.9375rem;
    padding-right: 10.75rem;
  }
  .every .mv__img {
    width: auto;
    height: 100%;
    max-width: 100%;
    margin: initial;
  }
  .every .mv__logo-wrapper {
    width: 12rem;
  }
  .every .scene__categories {
    margin-top: 3.125rem;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(4, 16.875rem);
    column-gap: 2.19152rem;
    row-gap: 3.125rem;
    justify-content: center;
  }
  .every .features .features__list {
    grid-template-columns: repeat(3, 1fr);
  }
  .every .features__list {
    -webkit-column-gap: 4.375rem;
    -moz-column-gap: 4.375rem;
    column-gap: 4.375rem;
  }
  .every .how-to-use__video-block.video01 {
    margin-bottom: 5rem;
  }
  .every .specifications__head {
      width: 15.8125rem;
  }
  .every .present-wrapper {
    max-width: 1180px;
    margin: 7rem;
  }
  .every .present-wrapper {
      max-width: 1180px;
      padding: 5rem;
      border-radius: 2.5rem;
      margin: 7rem auto 0;
  }
  .every .present-title__en {
    font-size: 2rem;
  }
  .every .present-title__ja {
    font-size: 1.125rem;
  }
  .every .present-text-box {
    margin-top: 2.5rem;
    padding: 3.125rem 0;
    border-radius: 1.25rem;
    width: 100%;
    max-width: 920px;
  }
  .every .present-text {
    font-size: 1rem;
    line-height: 2;
    text-align: center;
  }
  .every .present-button-wrapper {
    max-width: 288px;
    margin: 2.5rem auto 0;
  }
  .every .present-text-lead,
  .every .present-text {
    text-align: center;
  }
  .every .present-text-cap-area {
    display: flex;
    justify-content: center;
  }
  .every .present-section .form-area {
    padding: 0 2rem;
  }
}


/* ==========================================
    CTAボタン調整
   ========================================== */
@media screen and (min-width: 768px) {
    .harnessplus .cta__list,
    .easylift .cta__list {
        grid-template-columns: unset;
        -webkit-column-gap: unset;
        -moz-column-gap: unset;
        column-gap: unset;
        max-width: 27.59375rem;
        margin: auto;
    }
}





