/*
* top.css
*
*/
/* Magnific Popup CSS */
.mfp-bg {
  overflow: hidden;
  opacity: 0.9;
  position: fixed;
  z-index: 1042;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #f9f9f9;
}

.mfp-wrap {
  position: fixed;
  z-index: 1043;
  top: 0;
  left: 0;
  outline: none !important;
  width: 100%;
  height: 100%;

  -webkit-backface-visibility: hidden;
}

.mfp-container {
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  padding: 0 8px;
  width: 100%;
  height: 100%;
  text-align: center;
}

.mfp-container::before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

.mfp-align-top .mfp-container::before {
  display: none;
}

.mfp-content {
  display: inline-block;
  position: relative;
  z-index: 1045;
  margin: 0 auto;
  text-align: left;
  vertical-align: middle;
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto;
}

.mfp-ajax-cur {
  cursor: progress;
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
     -moz-user-select: none;
          -ms-user-select: none;
      user-select: none;
}

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor:         zoom-out;
}

.mfp-zoom {
  cursor: pointer;
  cursor:         zoom-in;
}

.mfp-auto-cursor .mfp-content {
  cursor: auto;
}

.mfp-loading.mfp-figure {
  display: none;
}

.mfp-hide {
  display: none !important;
}

.mfp-preloader {
  position: absolute;
  z-index: 1044;
  top: 50%;
  right: 8px;
  left: 8px;
  margin-top: -0.8em;
  width: auto;
  text-align: center;
  color: #ccc;
}

.mfp-preloader a {
  color: #ccc;
}

.mfp-preloader a:hover {
  color: #fff;
}

.mfp-s-ready .mfp-preloader {
  display: none;
}

.mfp-s-error .mfp-content {
  display: none;
}

button.mfp-close,
button.mfp-arrow {
  display: block;
  overflow: visible;
  z-index: 1046;
  padding: 0;
  border: 0;
  outline: none;
  cursor: pointer;
  background: transparent;
  box-shadow: none;

  -webkit-appearance: none;
  touch-action: manipulation;
}

button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

button.mfp-close {
  opacity: 0.65;
  opacity: 1;
  position: relative;
  position: absolute;
  top: 0;
  right: 0;
  border-bottom: 1px solid #e9eae6;
  border-left: 1px solid #e9eae6;
  width: clamp(29px,3.88889vw, 56px);
  height: clamp(29px,3.88889vw, 56px);
  background-color: #fff;
  background-size: clamp(6px,0.83334vw, 12px) clamp(6px,0.83334vw, 12px);
}

button.mfp-close.-feature {
  top: -14.93333vw;
  background-color: transparent;
}

@media screen and (min-width: 768px) {
  button.mfp-close.-feature {
    top: -0.69444vw;
    right: -4.86111vw;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-feature {
    top: -10px;
    right: -70px;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-feature::before {
    width: 2.77778vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-feature::before {
    width: 40px !important;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-feature::after {
    width: 2.77778vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-feature::after {
    width: 40px !important;
  }
}

button.mfp-close.-system {
  top: -14.93333vw;
  background-color: transparent;
}

@media screen and (min-width: 768px) {
  button.mfp-close.-system {
    top: -0.69444vw;
    right: -5.34722vw;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-system {
    top: -10px;
    right: -77px;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-system::before {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-system::before {
    width: 56px !important;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-system::after {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-system::after {
    width: 56px !important;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-case {
    top: -0.69444vw;
    right: -5.34722vw;
    background-color: transparent;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-case {
    top: -10px;
    right: -77px;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-case::before {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-case::before {
    width: 56px !important;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-case::after {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-case::after {
    width: 56px !important;
  }
}

button.mfp-close.-price {
  top: -14.93333vw;
  background-color: transparent;
}

@media screen and (min-width: 768px) {
  button.mfp-close.-price {
    top: -0.69444vw;
    right: -5.34722vw;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-price {
    top: -10px;
    right: -77px;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-price::before {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-price::before {
    width: 56px !important;
  }
}

@media screen and (min-width: 768px) {
  button.mfp-close.-price::after {
    width: 3.88889vw !important;
  }
}

@media screen and (min-width: 1440px) {
  button.mfp-close.-price::after {
    width: 56px !important;
  }
}

button.mfp-close:before,
button.mfp-close:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: clamp(8px,1.04167vw, 15px);
  height: 2px;
  -webkit-transform-origin: center;
          transform-origin: center;
  background-color: #4a29b4;
}

button.mfp-close:before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

button.mfp-close:after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

button.mfp-close:hover,
button.mfp-close:focus {
  opacity: 1;
}

@media screen and (max-width: 768px) {
  button.mfp-close {
    width: 14.93333vw;
    height: 14.93333vw;
    background-size: 3.2vw 3.2vw;
  }
  button.mfp-close:before,
  button.mfp-close:after {
    top: 0.8vw;
    width: 4vw;
  }
}

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  white-space: nowrap;
  color: #ccc;
  font-size: 12px;
  line-height: 18px;
}

.mfp-arrow {
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: absolute;
  z-index: 1046;
  top: 50%;
  margin: 0;
  padding: 0;
  border-radius: clamp(1px,0.13889vw, 2px);
  width: clamp(28px,3.75vw, 54px);
  height: clamp(28px,3.75vw, 54px);
  transition: opacity 0.3s;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #4a28b4 !important;

  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.mfp-arrow:hover,
.mfp-arrow:focus {
  opacity: 0.9;
}

.mfp-arrow::before {
  content: "";
  display: block;
  width: clamp(5px,0.69445vw, 10px);
  height: clamp(6px,0.90278vw, 13px);
  background: url(/assets/img/common/icon_arrow_left_white.png) center no-repeat;
  background-size: contain;
}

@media screen and (max-width: 768px) {
  .mfp-arrow {
    border-radius: 0.53333vw;
    width: 14.4vw;
    height: 14.4vw;
  }
  .mfp-arrow::before {
    width: 2.66667vw;
    height: 3.46667vw;
  }
}

.mfp-arrow-left {
  left: clamp(-13px,-1.59722vw, -23px);
}

@media screen and (max-width: 768px) {
  .mfp-arrow-left {
    left: -6.93333vw;
  }
}

.mfp-arrow-right {
  right: clamp(-13px,-1.59722vw, -23px);
}

.mfp-arrow-right::before {
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}

@media screen and (max-width: 768px) {
  .mfp-arrow-right {
    right: -6.93333vw;
  }
}

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px;
}

.mfp-iframe-holder .mfp-content {
  width: 100%;
  max-width: 173.33333vw;
  line-height: 0;
}

@media screen and (min-width: 768px) {
  .mfp-iframe-holder .mfp-content {
    max-width: 83.33333vw;
  }
}

@media screen and (min-width: 1440px) {
  .mfp-iframe-holder .mfp-content {
    max-width: 1200px;
  }
}

.mfp-iframe-scaler {
  overflow: hidden;
  padding-top: 56.25%;
  width: 100%;
  height: 0;
}

.mfp-iframe-scaler iframe {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

/* Main image in popup */
img.mfp-img {
  display: block;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 40px 0 40px;
  width: auto;
  max-width: 100%;
  height: auto;
  line-height: 0;
}

/* The shadow behind the image */
.mfp-figure {
  line-height: 0;
}

.mfp-figure::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  top: 40px;
  right: 0;
  bottom: 40px;
  left: 0;
  width: auto;
  height: auto;
  background: #444;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}

.mfp-figure small {
  display: block;
  color: #bdbdbd;
  font-size: 12px;
  line-height: 14px;
}

.mfp-figure figure {
  margin: 0;
}

.mfp-bottom-bar {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: -36px;
  width: 100%;
  cursor: auto;
}

.mfp-title {
  padding-right: 36px;
  text-align: left;
  word-wrap: break-word;
  color: #f3f3f3;
  line-height: 18px;
}

.mfp-image-holder .mfp-content {
  max-width: 100%;
}

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer;
}

@media screen and (max-width: 768px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
       * Remove all paddings around the image on small screen
       */
  .mfp-img-mobile .mfp-image-holder {
    padding-right: 0;
    padding-left: 0;
  }
  .mfp-img-mobile img.mfp-img {
    padding: 0;
  }
  .mfp-img-mobile .mfp-figure::after {
    top: 0;
    bottom: 0;
  }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px;
  }
  .mfp-img-mobile .mfp-bottom-bar {
    box-sizing: border-box;
    position: fixed;
    top: auto;
    bottom: 0;
    margin: 0;
    padding: 3px 5px;
    background: rgba(0, 0, 0, 0.6);
  }
  .mfp-img-mobile .mfp-bottom-bar:empty {
    padding: 0;
  }
  .mfp-img-mobile .mfp-counter {
    top: 3px;
    right: 5px;
  }
  .mfp-img-mobile .mfp-close {
    position: fixed;
    top: 0;
    right: 0;
    padding: 0;
    width: 35px;
    height: 35px;
    background: rgba(0, 0, 0, 0.6);
    text-align: center;
    line-height: 35px;
  }
}

.mfp-fade {
  /* overlay at start */
  /* content at start */
}

.mfp-fade.mfp-bg {
  opacity: 0;
  transition: all 0.25s ease-out;
  /* overlay animate in */
  /* overlay animate out */
}

.mfp-fade.mfp-bg.mfp-ready {
  opacity: 1;
}

.mfp-fade.mfp-bg.mfp-removing {
  opacity: 0;
}

.mfp-fade.mfp-wrap {
  /* content animate it */
  /* content animate out */
}

.mfp-fade.mfp-wrap .mfp-content,
.mfp-fade.mfp-wrap .mfp-arrow {
  opacity: 0;
  transition: all 0.25s ease-out;
}

.mfp-fade.mfp-wrap.mfp-ready .mfp-content,
.mfp-fade.mfp-wrap.mfp-ready .mfp-arrow {
  opacity: 1;
}

.mfp-fade.mfp-wrap.mfp-removing .mfp-content,
.mfp-fade.mfp-wrap.mfp-removing .mfp-arrow {
  opacity: 0;
}

main {
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

[data-load="loaded"] main {
  opacity: 1;
}

.opening {
  position: fixed;
  z-index: 99999;
  background: #fff;

  inset: 0;
  -webkit-perspective: 133.33333vw;
          perspective: 133.33333vw;
}

[data-load="loaded"] .opening {
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), visibility 0.3s;
}

[data-load="loaded"] .opening .opening__icon {
  -webkit-animation: none;
          animation: none;
}

.opening .opening__icon {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 20.8vw;
  height: 22.4vw;
  -webkit-animation: rotate3 4s linear 0s infinite normal;
          animation: rotate3 4s linear 0s infinite normal;
  background-image: url(/assets/img/common/icon_logo.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

@-webkit-keyframes rotate3 {
  0% {
    -webkit-transform: rotateY(0);
            transform: rotateY(0);
  }
  25%,
  75% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
  }
}

@keyframes rotate3 {
  0% {
    -webkit-transform: rotateY(0);
            transform: rotateY(0);
  }
  25%,
  75% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
  }
}

@media screen and (min-width: 768px) {
  .opening .opening__icon {
    width: 78px;
    height: 84px;
  }
}

.intermediate__img {
  width: 100vw;
}

@media screen and (min-width: 768px) {
  .intermediate__img {
    width: 100%;
  }
}

.c-topButton {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin: auto;
  border-radius: 0.53333vw;
  width: 89.33333vw;
  height: 13.33333vw;
  background-color: #d5ad58;
  white-space: nowrap;
  color: #fff !important;
  font-size: 3.73333vw;
}

@media screen and (min-width: 768px) {
  .c-topButton {
    margin: 0;
    border-radius: 2px;
    width: 20.48611vw;
    height: 3.47222vw;
    transition: background-color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1);
    font-size: 1.11111vw;
    line-height: 3.47222vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton {
    width: 295px;
    height: 50px;
    font-size: 16px;
    line-height: 50px;
  }
}

.c-topButton.feature__topButton {
  margin-top: 9.6vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.feature__topButton {
    position: absolute;
    z-index: 1;
    top: 31.94444vw;
    left: 52.77778vw;
    margin-top: 4.16667vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.feature__topButton {
    top: 460px;
    left: 760px;
    margin-top: 60px;
  }
}

.c-topButton.feature__topButton.-doctor {
  margin-top: 2.66667vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.feature__topButton.-doctor {
    position: absolute;
    z-index: 1;
    top: 36.11111vw;
    left: 52.77778vw;
    margin-top: 4.16667vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.feature__topButton.-doctor {
    top: 520px;
    left: 760px;
    margin-top: 60px;
  }
}

.c-topButton.column__topButton {
  margin-top: 9.6vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.column__topButton {
    position: absolute;
    top: 19.79167vw;
    margin-top: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.column__topButton {
    top: 285px;
  }
}

.c-topButton.system__topButton {
  margin-top: 9.6vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.system__topButton {
    position: absolute;
    z-index: 1;
    top: 21.18056vw;
    left: 0;
    margin-top: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.system__topButton {
    top: 305px;
    left: 0;
  }
}

.c-topButton.access__topButton {
  margin-top: 9.6vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.access__topButton {
    position: absolute;
    z-index: 1;
    top: 20.55556vw;
    left: 56.59722vw;
    margin-top: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.access__topButton {
    top: 296px;
    left: 815px;
  }
}

.c-topButton.price__topButton {
  margin-top: 9.6vw;
}

@media screen and (min-width: 768px) {
  .c-topButton.price__topButton {
    position: absolute;
    z-index: 1;
    top: 25vw;
    left: 56.59722vw;
    margin-top: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-topButton.price__topButton {
    top: 360px;
    left: 815px;
  }
}

.c-sectionTitle__wrapper {
  padding-left: 5.33333vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper {
    padding-left: 0;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper.-feature {
    position: absolute;
    z-index: 1;
    top: 11.80556vw;
    left: 52.77778vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__wrapper.-feature {
    top: 170px;
    left: 760px;
  }
}

.c-sectionTitle__wrapper.-column {
  padding-left: 0;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper.-system {
    position: absolute;
    z-index: 1;
    top: 3.61111vw;
    left: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__wrapper.-system {
    top: 52px;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper.-price {
    position: absolute;
    z-index: 1;
    top: 1.66667vw;
    left: 56.59722vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__wrapper.-price {
    top: 24px;
    left: 815px;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper.-faq {
    position: absolute;
    z-index: 1;
    top: -2.08333vw;
    left: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__wrapper.-faq {
    top: -30px;
  }
}

.c-sectionTitle__wrapper.-access {
  padding-left: 0;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__wrapper.-access {
    position: absolute;
    z-index: 1;
    top: 2.77778vw;
    left: 56.59722vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__wrapper.-access {
    top: 40px;
    left: 815px;
  }
}

.c-sectionTitle__sub {
  display: flex;
  align-items: center;
  position: relative;
  margin-left: 3.73333vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub {
    margin-left: 0.69444vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub {
    margin-left: 17px;
  }
}

.c-sectionTitle__sub::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: -3.2vw;
  margin: auto;
  border-radius: 0.26667vw;
  width: 1.6vw;
  height: 1.6vw;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #d5ad58;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub::before {
    left: -1.11111vw;
    border-radius: 1px;
    width: 0.55556vw;
    height: 0.55556vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub::before {
    left: -16px;
    width: 8px;
    height: 8px;
  }
}

.c-sectionTitle__sub.-feature {
  width: 13.6vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-feature {
    top: 1.11111vw;
    width: 4.51389vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-feature {
    top: 16px;
    width: 65px;
  }
}

.c-sectionTitle__sub.-column {
  width: 14.66667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-column {
    top: 1.52778vw;
    width: 4.93056vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-column {
    top: 22px;
    width: 71px;
  }
}

.c-sectionTitle__sub.-system {
  width: 12vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-system {
    top: 1.52778vw;
    width: 3.95833vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-system {
    top: 22px;
    width: 57px;
  }
}

.c-sectionTitle__sub.-access {
  width: 11.73333vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-access {
    top: 1.52778vw;
    width: 3.95833vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-access {
    top: 22px;
    width: 57px;
  }
}

.c-sectionTitle__sub.-price {
  width: 9.06667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-price {
    width: 2.98611vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-price {
    width: 43px;
  }
}

.c-sectionTitle__sub.-faq {
  width: 7.46667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__sub.-faq {
    top: 1.80556vw;
    width: 2.5vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__sub.-faq {
    top: 26px;
    width: 36px;
  }
}

.c-sectionTitle__main {
  margin-top: 2.66667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main {
    margin-top: 0;
  }
}

.c-sectionTitle__main.-feature {
  width: 50.66667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-feature {
    width: 23.88889vw;
    height: 3.26389vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-feature {
    width: 344px;
    height: 47px;
  }
}

.c-sectionTitle__main.-column {
  width: 22.66667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-column {
    width: 9.93056vw;
    height: 2.63889vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-column {
    width: 143px;
    height: 38px;
  }
}

.c-sectionTitle__main.-system {
  width: 43.2vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-system {
    width: 20.34722vw;
    height: 3.33333vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-system {
    width: 293px;
    height: 48px;
  }
}

.c-sectionTitle__main.-access {
  width: 31.2vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-access {
    width: 13.68056vw;
    height: 2.70833vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-access {
    width: 197px;
    height: 39px;
  }
}

.c-sectionTitle__main.-price {
  width: 50.93333vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-price {
    margin-top: 1.52778vw;
    width: 23.88889vw;
    height: 7.70833vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-price {
    margin-top: 22px;
    width: 344px;
    height: 111px;
  }
}

.c-sectionTitle__main.-faq {
  width: 49.06667vw;
}

@media screen and (min-width: 768px) {
  .c-sectionTitle__main.-faq {
    margin-top: 3.125vw;
    width: 23.125vw;
    height: 8.05556vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionTitle__main.-faq {
    margin-top: 45px;
    width: 333px;
    height: 116px;
  }
}

.c-sectionText {
  margin-top: 10.66667vw;
  padding: 0 5.33333vw;
  letter-spacing: 0.04em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .c-sectionText {
    margin-top: 0;
    padding: 0;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionText {
    font-size: 16px;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionText.-feature {
    position: absolute;
    z-index: 1;
    top: 22.08333vw;
    left: 52.77778vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionText.-feature {
    top: 318px;
    left: 760px;
    padding-right: 50px;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionText.-system {
    position: absolute;
    z-index: 1;
    top: 13.54167vw;
    left: 0;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionText.-system {
    top: 195px;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionText.-price {
    position: absolute;
    z-index: 1;
    top: 15.27778vw;
    left: 56.59722vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionText.-price {
    top: 220px;
    left: 815px;
  }
}

@media screen and (max-width: 767px) {
  .c-sectionText.-faq {
    margin-top: 10.66667vw;
  }
}

@media screen and (min-width: 768px) {
  .c-sectionText.-faq {
    position: absolute;
    z-index: 1;
    top: 12.15278vw;
    left: 0;
    width: 24.23611vw;
  }
}

@media screen and (min-width: 1440px) {
  .c-sectionText.-faq {
    top: 175px;
    width: 349px;
  }
}

.mv {
  position: relative;
  height: 148.8vw;
}

@media screen and (min-width: 768px) {
  .mv {
    height: 45.13889vw;
  }
}

.mv__inner {
  overflow: hidden;
  position: absolute;

  inset: 0;
}

.mv__icon {
  position: absolute;
  z-index: 2;
  top: 5.33333vw;
  left: 8.53333vw;
  width: 14.13333vw;
}

@media screen and (min-width: 768px) {
  .mv__icon {
    display: none;
  }
}

.mv__bg {
  position: absolute;

  inset: 0;
}

.mv__bg__img01 {
  position: absolute;
  z-index: 1;

  inset: 0 0 0 0;
}

@media screen and (min-width: 768px) {
  .mv__bg__img01 img {
    width: 61.45833vw;
  }
}

.mv__bg__img02 {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  position: absolute;

  inset: 0 0 0 0;
}

.mv__bg__img02 img {
  margin-top: auto;
}

@media screen and (min-width: 768px) {
  .mv__bg__img02 img {
    width: 61.45833vw;
  }
}

.mv__visual__lead {
  position: absolute;
  top: 94.93333vw;
  left: 10.66667vw;
  width: 37.33333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__lead {
    top: 7.22222vw;
    left: 56.80556vw;
    width: 12.77778vw;
  }
}

.mv__visual__content {
  position: absolute;

  inset: 0;
}

.mv__visual__img {
  display: inline-block;
  opacity: 0;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  height: 11.46667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img {
    height: 6.11111vw;
  }
}

.mv__visual__img img {
  width: auto;
  height: 100%;
}

.mv__visual__img.img01 {
  inset: 28.26667vw auto auto 9.86667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img01 {
    inset: 5.13889vw auto auto 27.43056vw;
  }
}

.mv__visual__img.img02 {
  inset: 28.26667vw auto auto 22.13333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img02 {
    inset: 5.13889vw auto auto 34.16667vw;
  }
}

.mv__visual__img.img03 {
  inset: 28.26667vw auto auto 31.2vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img03 {
    inset: 5.13889vw auto auto 39.16667vw;
  }
}

.mv__visual__img.img04 {
  inset: 28.26667vw auto auto 36.8vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img04 {
    inset: 5.13889vw auto auto 42.36111vw;
  }
}

.mv__visual__img.img05 {
  inset: 28.26667vw auto auto 50.13333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img05 {
    inset: 5.13889vw auto auto 49.44444vw;
  }
}

.mv__visual__img.img06 {
  inset: 45.6vw auto auto 10.66667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img06 {
    inset: 14.65278vw auto auto 27.84722vw;
  }
}

.mv__visual__img.img07 {
  inset: 45.6vw auto auto 22.4vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img07 {
    inset: 14.65278vw auto auto 34.375vw;
  }
}

.mv__visual__img.img08 {
  inset: 45.6vw auto auto 35.73333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img08 {
    inset: 14.65278vw auto auto 41.59722vw;
  }
}

.mv__visual__img.img09 {
  inset: 45.6vw auto auto 47.73333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img09 {
    inset: 14.65278vw auto auto 48.19444vw;
  }
}

.mv__visual__img.img10 {
  inset: 45.6vw auto auto 57.86667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img10 {
    inset: 14.65278vw auto auto 53.95833vw;
  }
}

.mv__visual__img.img11 {
  inset: 45.6vw auto auto 70.93333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img11 {
    inset: 14.65278vw auto auto 61.11111vw;
  }
}

.mv__visual__img.img12 {
  inset: 45.6vw auto auto 82.4vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img12 {
    inset: 14.65278vw auto auto 67.29167vw;
  }
}

.mv__visual__img.img13 {
  inset: 63.2vw auto auto 10.93333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img13 {
    inset: 24.23611vw auto auto 27.98611vw;
  }
}

.mv__visual__img.img14 {
  inset: 63.2vw auto auto 24.8vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img14 {
    inset: 24.23611vw auto auto 35.55556vw;
  }
}

.mv__visual__img.img15 {
  inset: 63.2vw auto auto 33.6vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img15 {
    inset: 24.23611vw auto auto 40.48611vw;
  }
}

.mv__visual__img.img16 {
  inset: 63.2vw auto auto 46.66667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img16 {
    inset: 24.23611vw auto auto 47.70833vw;
  }
}

.mv__visual__img.img17 {
  inset: 63.2vw auto auto 56.53333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img17 {
    inset: 24.23611vw auto auto 52.84722vw;
  }
}

.mv__visual__img.img18 {
  inset: 63.2vw auto auto 68.26667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img18 {
    inset: 24.23611vw auto auto 59.51389vw;
  }
}

.mv__visual__img.img19 {
  inset: 80.26667vw auto auto 10.66667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img19 {
    inset: 33.68056vw auto auto 27.84722vw;
  }
}

.mv__visual__img.img20 {
  inset: 80.26667vw auto auto 24.53333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img20 {
    inset: 33.68056vw auto auto 35.48611vw;
  }
}

.mv__visual__img.img21 {
  inset: 80.26667vw auto auto 33.33333vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img21 {
    inset: 33.68056vw auto auto 40.34722vw;
  }
}

.mv__visual__img.img22 {
  inset: 80.26667vw auto auto 42.4vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img22 {
    inset: 33.68056vw auto auto 45.27778vw;
  }
}

.mv__visual__img.img23 {
  inset: 80.26667vw auto auto 48.26667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img23 {
    inset: 33.68056vw auto auto 48.61111vw;
  }
}

.mv__visual__img.img24 {
  inset: 80.26667vw auto auto 60.26667vw;
}

@media screen and (min-width: 768px) {
  .mv__visual__img.img24 {
    inset: 33.68056vw auto auto 55.27778vw;
  }
}

.mv__scroll {
  display: block;
  position: absolute;
  margin: auto;
  text-align: center;
  letter-spacing: 0.18em;
  pointer-events: none;
  color: #9c9c9c;
  font-size: 2.93333vw;
  line-height: 1;

  inset: auto 0 11.2vw 0;
}

@media screen and (min-width: 768px) {
  .mv__scroll {
    font-size: 0.83333vw;

    inset: auto 0 2.77778vw 0;
  }
}

@media screen and (min-width: 1440px) {
  .mv__scroll {
    font-size: 12px;

    inset: auto 0 40px 0;
  }
}

.mv__scroll span {
  content: "";
  position: absolute;
  margin: auto;
  width: 1px;
  height: 16vw;
  background-color: #d0d0d0;

  inset: auto 0 -19.73333vw 0;
}

@media screen and (min-width: 768px) {
  .mv__scroll span {
    height: 4.16667vw;

    inset: auto 0 -5.13889vw 0;
  }
}

@media screen and (min-width: 1440px) {
  .mv__scroll span {
    height: 60px;

    inset: auto 0  -74px 0;
  }
}

/* ----------------------------------------------*
* about
*---------------------------------------------- */
.about {
  padding-top: 21.33333vw;
  padding-bottom: 21.33333vw;
  background: #fff;
}

@media screen and (min-width: 768px) {
  .about {
    padding: 13.54167vw 0 13.54167vw;
  }
}

@media screen and (min-width: 1440px) {
  .about {
    padding: 195px 0;
  }
}

.about__title {
  text-align: left;
  white-space: nowrap;
  letter-spacing: 0.09em;
  color: #4d4d4d;
  font-size: 7.46667vw;
  font-weight: 400;
  line-height: 1.57143;
}

@media screen and (min-width: 768px) {
  .about__title {
    text-align: center;
    letter-spacing: 0.2em;
    font-size: 2.91667vw;
    line-height: 1.42857;
  }
}

@media screen and (min-width: 1440px) {
  .about__title {
    font-size: 42px;
  }
}

.about__lead {
  padding-top: 10.66667vw;
  font-size: 4.26667vw;
  line-height: 2.1875;
}

@media screen and (min-width: 768px) {
  .about__lead {
    margin: 0 auto;
    padding-top: 3.47222vw;
    text-align: center;
    letter-spacing: 0.1em;
    font-size: 1.66667vw;
    line-height: 1.66667;
  }
}

@media screen and (min-width: 1440px) {
  .about__lead {
    padding-top: 50px;
    font-size: 24px;
  }
}

.about__text {
  padding-top: 8.8vw;
  font-size: 3.73333vw;
  line-height: 2.5;
}

@media screen and (min-width: 768px) {
  .about__text {
    margin: 0 auto;
    padding-top: 3.61111vw;
    text-align: center;
    letter-spacing: 0.1em;
    font-size: 1.25vw;
    line-height: 2.22222;
  }
}

@media screen and (min-width: 1440px) {
  .about__text {
    padding-top: 52px;
    font-size: 18px;
  }
}

/* ----------------------------------------------*
* feature
*---------------------------------------------- */
.feature {
  padding: 18.66667vw 0 20vw;
}

@media screen and (min-width: 768px) {
  .feature {
    padding: 13.88889vw 0 6.94444vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature {
    padding: 200px 0 100px;
  }
}

.feature__inner {
  margin-top: 17.33333vw;
  padding: 0 5.33333vw;
}

@media screen and (min-width: 768px) {
  .feature__inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: 12.5vw;
    padding: 0;
  }
}

@media screen and (min-width: 1440px) {
  .feature__inner {
    margin-top: 180px;
  }
}

.feature__imgArea {
  position: relative;
  margin-top: 10.66667vw;
  height: 100vw;
}

@media screen and (min-width: 768px) {
  .feature__imgArea {
    margin-top: 0;
    height: 48.95833vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__imgArea {
    height: 705px;
  }
}

.feature__imgWrapper {
  position: absolute;
}

.feature__imgWrapper .feature__img {
  display: block;
  position: absolute;
  margin: auto;

  inset: 0;
}

.feature__imgWrapper.-top {
  top: 0;
  left: 0;
  width: 72.53333vw;
  height: 90.66667vw;
}

@media screen and (min-width: 768px) {
  .feature__imgWrapper.-top {
    width: 35vw;
    height: 43.75vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__imgWrapper.-top {
    width: 504px;
    height: 630px;
  }
}

.feature__imgWrapper.-bottom {
  right: 5.33333vw;
  bottom: 0;
  width: 40vw;
  height: 53.33333vw;
}

@media screen and (min-width: 768px) {
  .feature__imgWrapper.-bottom {
    right: auto;
    left: 28.81944vw;
    width: 18.47222vw;
    height: 24.58333vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__imgWrapper.-bottom {
    left: 415px;
    width: 266px;
    height: 354px;
  }
}

.slide-container {
  position: relative;
  width: 100%;
}

.slide-img {
  position: absolute;
}

.feature__profile {
  padding: 3.2vw 5.33333vw 0;
}

@media screen and (min-width: 768px) {
  .feature__profile {
    position: absolute;
    bottom: 0;
    padding: 0;
    line-height: 1;
  }
}

.feature__profile__pos {
  letter-spacing: 0.05em;
  font-size: 3.2vw;
}

@media screen and (min-width: 768px) {
  .feature__profile__pos {
    font-size: 0.97222vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__profile__pos {
    font-size: 14px;
  }
}

.feature__profile__name {
  display: flex;
  align-items: center;
  font-size: 5.86667vw;

  gap: 2.13333vw;
}

@media screen and (min-width: 768px) {
  .feature__profile__name {
    padding-top: 0.83333vw;
    font-size: 2.22222vw;

    gap: 0.97222vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__profile__name {
    padding-top: 12px;
    font-size: 32px;

    gap: 14px;
  }
}

.feature__profile__name .feature__profile__name__small {
  font-size: 3.2vw;
}

@media screen and (min-width: 768px) {
  .feature__profile__name .feature__profile__name__small {
    font-size: 0.83333vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__profile__name .feature__profile__name__small {
    font-size: 12px;
  }
}

.linkArea {
  position: relative;
  padding: 8vw 0 0;
}

@media screen and (min-width: 768px) {
  .linkArea {
    padding: 3.26389vw 0 0 3.05556vw;
    border-radius: 4px;
    width: 40.27778vw;
    background-color: #fff;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea {
    padding: 47px 0 0 44px;
    width: 580px;
  }
}

.linkArea + .linkArea {
  margin-top: 17.6vw;
}

@media screen and (min-width: 768px) {
  .linkArea + .linkArea {
    margin-top: 0;
    margin-left: 2.77778vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea + .linkArea {
    margin-left: 40px;
  }
}

.linkArea::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 1px;
  background-color: #e8e8e8;
}

.linkArea.-review::before {
  content: "";
  display: block;
  position: absolute;
  top: -1.6vw;
  left: 0;
  width: 15.73333vw;
  height: 2.93333vw;
  background-image: url(/assets/img/top/review.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .linkArea.-review::before {
    top: -1.04167vw;
    left: -1.94444vw;
    width: 4.93056vw;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}

@media screen and (min-width: 1440px) {
  .linkArea.-review::before {
    top: -15px;
    left: -28px;
    width: 71px;
  }
}

.linkArea.-review::after {
  width: 70.66667vw;
}

@media screen and (min-width: 768px) {
  .linkArea.-review::after {
    top: 11.11111vw;
    left: -5.41667vw;
    width: 14.58333vw;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}

@media screen and (min-width: 1440px) {
  .linkArea.-review::after {
    top: 160px;
    left: -78px;
    width: 210px;
  }
}

@media screen and (min-width: 768px) {
  .linkArea.-case {
    margin-top: 6.80556vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea.-case {
    margin-top: 98px;
  }
}

.linkArea.-case::before {
  content: "";
  display: block;
  position: absolute;
  top: -1.6vw;
  left: 0;
  width: 15.73333vw;
  height: 2.93333vw;
  background-image: url(/assets/img/top/case.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .linkArea.-case::before {
    top: -1.52778vw;
    left: -0.90278vw;
    width: 2.98611vw;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}

@media screen and (min-width: 1440px) {
  .linkArea.-case::before {
    top: -22px;
    left: -13px;
    width: 43px;
  }
}

.linkArea.-case::after {
  width: 76.26667vw;
}

@media screen and (min-width: 768px) {
  .linkArea.-case::after {
    top: 9.72222vw;
    left: -5.41667vw;
    width: 14.58333vw;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}

@media screen and (min-width: 1440px) {
  .linkArea.-case::after {
    top: 140px;
    left: -78px;
    width: 210px;
  }
}

@media screen and (min-width: 768px) {
  .linkArea__pcWrapper {
    display: flex;
  }
}

@media screen and (max-width: 767px) {
  .linkArea__pcWrapper__contents.-spNone {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .linkArea__pcWrapper__contents.-padding {
    padding-right: 3.33333vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__pcWrapper__contents.-padding {
    padding-right: 48px;
  }
}

@media screen and (min-width: 768px) {
  .linkArea__pcWrapper__contents + .linkArea__pcWrapper__contents {
    margin-left: 1.66667vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__pcWrapper__contents + .linkArea__pcWrapper__contents {
    margin-left: 24px;
  }
}

@media screen and (min-width: 768px) {
  .linkArea__img {
    width: 13.05556vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__img {
    width: 188px;
  }
}

.linkArea__title {
  letter-spacing: 0.04em;
  color: #d5ad58;
  font-size: 5.86667vw;
  font-weight: normal;
  line-height: 1.45455;
}

@media screen and (min-width: 768px) {
  .linkArea__title {
    margin-top: -1.86667vw;
    font-size: 1.66667vw;
    line-height: 1.48;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__title {
    margin-top: -7px;
    font-size: 24px;
  }
}

.linkArea__text {
  margin-top: 3.73333vw;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .linkArea__text {
    margin-top: 1.04167vw;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__text {
    margin-top: 15px;
    font-size: 16px;
  }
}

.linkArea__link {
  display: flex;
  align-items: center;
  position: relative;
  margin-top: 9.33333vw;
  padding: 4.53333vw 3.2vw;
  border-radius: 0.53333vw;
  background-color: #f2ead9;
  font-size: 3.73333vw;
}

@media screen and (min-width: 768px) {
  .linkArea__link {
    margin-top: 2.56944vw;
    padding: 0;
    border-radius: 4px 0;
    height: 3.47222vw;
    transition: background-color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1);
    font-size: 1.11111vw;
    line-height: 3.47222vw;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__link {
    margin-top: 37px;
    padding: 0;
    height: 50px;
    font-size: 16px;
    line-height: 50px;
  }
}

@media screen and (min-width: 768px) {
  .linkArea__link:hover {
    transition: background-color 0.25s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
    background-color: #d5ad58;
    color: #fff;
  }
}

.linkArea__linkImg {
  width: 26.66667vw;
}

@media screen and (min-width: 768px) {
  .linkArea__linkImg {
    display: none;
  }
}

.linkArea__linkText {
  margin-left: 6.93333vw;
  font-size: 3.73333vw;
  line-height: 1.82143;
}

@media screen and (min-width: 768px) {
  .linkArea__linkText {
    margin-left: 2.77778vw;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .linkArea__linkText {
    margin-left: 40px;
    font-size: 16px;
  }
}

.feature__row {
  display: flex;
  flex-flow: column;
  margin-top: 5.33333vw;
  padding: 0 5.33333vw;
}

@media screen and (min-width: 768px) {
  .feature__row {
    margin-top: 1.38889vw;
    padding: 0;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row {
    margin-top: 20px;
  }
}

.feature__row__item {
  display: flex;
  flex-flow: column-reverse;
  margin-top: 16vw;

  gap: 10.66667vw;
}

@media screen and (min-width: 768px) {
  .feature__row__item {
    align-items: center;
    flex-flow: row;
    margin-top: 6.94444vw;
    margin-right: calc((100vw - 100% - 15px) / 2 * -1);

    gap: 0;
  }
}

@media screen and (min-width: 1600px) {
  .feature__row__item {
    margin-top: 100px;
    margin-right: 0;
  }
}

@media screen and (min-width: 768px) {
  .feature__row__item:nth-child(2n) {
    flex-flow: row-reverse;
    margin-right: 0;
    margin-left: calc((100vw - 100%) / 2 * -1);
  }
}

@media screen and (min-width: 1600px) {
  .feature__row__item:nth-child(2n) {
    margin-left: 0;
  }
}

.feature__row__item__text {
  flex: 1;
}

@media screen and (min-width: 768px) {
  .feature__row__item__text {
    padding: 4.86111vw 3.19444vw;
    background-color: #fff;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__text {
    padding: 70px 46px;
  }
}

.feature__row__item__text__heading {
  letter-spacing: 0.02em;
  color: #d5ad58;
  font-size: 5.86667vw;
  line-height: 1.36364;
}

@media screen and (min-width: 768px) {
  .feature__row__item__text__heading {
    letter-spacing: 0.04em;
    font-size: 1.66667vw;
    line-height: 1.5;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__text__heading {
    font-size: 24px;
  }
}

.feature__row__item__text__heading-small {
  margin-top: 6.66667vw;
  letter-spacing: 0.01em;
  color: #d5ad58;
  font-size: 4.26667vw;
  line-height: 1;
}

@media screen and (min-width: 768px) {
  .feature__row__item__text__heading-small {
    margin-top: 2.08333vw;
    letter-spacing: 0.04em;
    font-size: 1.25vw;
    line-height: 1;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__text__heading-small {
    margin-top: 30px;
    font-size: 18px;
  }
}

.feature__row__item__text__lead {
  margin-top: 3.73333vw;
  letter-spacing: 0.02em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .feature__row__item__text__lead {
    margin-top: 1.04167vw;
    letter-spacing: 0.04em;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__text__lead {
    margin-top: 15px;
    font-size: 16px;
  }
}

.feature__row__item__text__lead.-last {
  margin-top: 2.66667vw;
}

@media screen and (min-width: 768px) {
  .feature__row__item__text__lead.-last {
    margin-top: 0.69444vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__text__lead.-last {
    margin-top: 10px;
  }
}

.feature__row__item__text__lead__highlight {
  background: linear-gradient(transparent 65%, #f0dfb9 0%);
  font-weight: bold;
}

.feature__row__item__img {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .feature__row__item__img {
    width: 50vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__item__img {
    width: 720px;
  }
}

.feature__row__detail__button {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .feature__row__detail__button {
    height: 27.2vw;
  }
  .feature__row__detail__button .linkArea__linkText {
    margin-left: 0;
  }
}

@media screen and (min-width: 768px) {
  .feature__row__detail__button {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 37.15278vw;
  }
}

@media screen and (min-width: 1440px) {
  .feature__row__detail__button {
    width: 535px;
  }
}

/* ----------------------------------------------*
* column
*---------------------------------------------- */
.column {
  padding: 18.66667vw 5.33333vw 21.33333vw;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .column {
    padding: 11.875vw 0 14.58333vw;
  }
}

@media screen and (min-width: 1440px) {
  .column {
    padding: 171px 0 210px;
  }
}

@media screen and (min-width: 768px) {
  .column__wrapper {
    display: flex;
    justify-content: space-between;
  }
}

.column__text {
  margin-top: 9.06667vw;
  letter-spacing: 0.04em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .column__text {
    margin-top: 5.41667vw;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .column__text {
    margin-top: 78px;
    font-size: 16px;
  }
}

.column__list {
  display: flex;
  flex-flow: wrap;
  margin-top: 8.53333vw;
  border-top: 1px solid #e8e8e8;
  border-bottom: 1px solid #e8e8e8;
}

@media screen and (min-width: 768px) {
  .column__list {
    margin-top: 2.08333vw;
    width: 52.08333vw;
  }
}

@media screen and (min-width: 1440px) {
  .column__list {
    margin-top: 30px;
    width: 750px;
  }
}

.column-card {
  display: flex;
  position: relative;
  padding: 4.8vw 3.2vw;
  width: 100%;
  min-height: 37.33333vw;
}

@media screen and (min-width: 768px) {
  .column-card {
    padding: 2.22222vw 1.25vw;
    min-height: 10.76389vw;
    transition: background-color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
}

@media screen and (min-width: 1440px) {
  .column-card {
    padding: 32px 18px;
    min-height: 155px;
  }
}

.column-card + .column-card {
  border-top: 1px solid #e8e8e8;
}

.column-card .-arrow {
  overflow: hidden;
  position: absolute;
  right: 3.46667vw;
  bottom: 4vw;
  width: 21.33333vw;
  height: 4px;
}

@media screen and (min-width: 768px) {
  .column-card .-arrow {
    top: 50%;
    right: 0.69444vw;
    width: 2.36111vw;
    height: 0.27778vw;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

@media screen and (min-width: 1440px) {
  .column-card .-arrow {
    right: 10px;
    width: 34px;
    height: 4px;
  }
}

.column-card .-arrow::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 21.33333vw;
  height: 4px;
  background-image: url(/assets/img/common/arw.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .column-card .-arrow::before {
    width: 2.36111vw;
    height: 0.27778vw;
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
    background-image: url(/assets/img/common/arw_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .-arrow::before {
    width: 34px;
    height: 4px;
  }
}

.column-card .-arrow::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 21.33333vw;
  height: 4px;
  background-image: url(/assets/img/common/arw.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .column-card .-arrow::after {
    width: 2.36111vw;
    height: 0.27778vw;
    background-image: url(/assets/img/common/arw_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .-arrow::after {
    width: 34px;
    height: 4px;
  }
}

.column-card .column-card-detail {
  flex: 1;
  width: 100%;
  text-align: left;
}

.column-card .column-card-detail__img {
  overflow: hidden;
  margin-top: 1.33333vw;
  margin-left: 3.73333vw;
  width: 32.26667vw;
  height: 21.86667vw;
}

.column-card .column-card-detail__img img {
  width: 100%;
  height: 100%;

  -o-object-fit: cover;

     object-fit: cover;
}

@media screen and (min-width: 768px) {
  .column-card .column-card-detail__img img {
    transition: -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1), -webkit-transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
}

@media screen and (min-width: 768px) {
  .column-card .column-card-detail__img {
    overflow: hidden;
    margin-top: 0;
    margin-right: 4.30556vw;
    margin-left: 0;
    width: 9.58333vw;
    height: 6.52778vw;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .column-card-detail__img {
    margin-right: 62px;
    width: 138px;
    height: 94px;
  }
}

.column-card:hover {
  transition: background-color 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: #f9f9f9;
}

@media screen and (min-width: 768px) {
  .column-card:hover .column-card-detail__title {
    transition: color 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
    color: #d5ad58;
  }
}

@media screen and (min-width: 768px) {
  .column-card:hover .column-card-detail__img img {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}

@media screen and (min-width: 768px) {
  .column-card:hover .-arrow::before {
    transition: -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: 0.1s;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@media screen and (min-width: 768px) {
  .column-card:hover .-arrow::after {
    transition: -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translateX(110%);
            transform: translateX(110%);
  }
}

.column-card .column-card-detail__tag {
  display: inline-block;
  padding: 1.33333vw 2.66667vw;
  border: 1px solid #d5ad58;
  border-radius: 16px;
  color: #d5ad58;
  font-size: 2.93333vw;
  line-height: 1;
}

@media screen and (min-width: 768px) {
  .column-card .column-card-detail__tag {
    padding: 0.27778vw 0.69444vw;
    border-radius: 11px;
    font-size: 0.83333vw;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .column-card-detail__tag {
    padding: 4px 10px;
    font-size: 12px;
  }
}

.column-card .column-card-detail__title {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  margin-top: 2.66667vw;
  letter-spacing: 0.04em;
  color: #4d4d4d;
  font-size: 3.2vw;
  font-weight: normal;
  line-height: 1.4;

  -webkit-line-clamp: 3;
}

@media screen and (min-width: 768px) {
  .column-card .column-card-detail__title {
    margin-top: 0.69444vw;
    transition: color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1);
    font-size: 0.97222vw;
    line-height: 1.91667;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .column-card-detail__title {
    margin-top: 10px;
    font-size: 14px;
  }
}

.column-card .column-card-detail__date {
  display: inline-block;
  position: absolute;
  bottom: 4vw;
  color: #999;
  font-size: 2.93333vw;
}

@media screen and (min-width: 768px) {
  .column-card .column-card-detail__date {
    position: relative;
    bottom: 0;
    font-size: 0.83333vw;
  }
}

@media screen and (min-width: 1440px) {
  .column-card .column-card-detail__date {
    font-size: 12px;
  }
}

.column__link {
  margin-top: 10.66667vw !important;
}

@media screen and (min-width: 768px) {
  .column__link {
    margin-top: 0;
  }
}

/* ----------------------------------------------*
* anchor
*---------------------------------------------- */
.anchor__text {
  padding: 0 5.33333vw;
  letter-spacing: 0.04em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .anchor__text {
    padding: 1.38889vw;
    text-align: center;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__text {
    padding: 0 20px;
    font-size: 16px;
  }
}

.anchor__list {
  margin-top: 9.33333vw;
  padding: 0 5.33333vw;
}

@media screen and (min-width: 768px) {
  .anchor__list {
    margin: 2.43056vw auto 0;
    padding: 3.33333vw;
    max-width: 83.33333vw;
    background-color: #fff;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list {
    margin: 35px auto 0;
    padding: 48px;
    max-width: 1200px;
  }
}

.anchor__list .anchor__head {
  position: relative;
  z-index: 1;
}

.anchor__list .anchor__head::before {
  content: "";
  position: absolute;
  z-index: -2;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #e8e8e8;
}

.anchor__list .anchor__head span {
  padding-right: 2.13333vw;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #f9f9f9;
  letter-spacing: 0.04em;
  color: #d5ad58;
  font-size: 5.86667vw;
  line-height: 1;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__head span {
    padding-right: 1.38889vw;
    background-color: #fff;
    font-size: 1.66667vw;
    line-height: 1.5;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__head span {
    padding-right: 20px;
    font-size: 24px;
  }
}

.anchor__list ul {
  display: -ms-grid;
  display: grid;
  margin-top: 6.66667vw;

  gap: 2.66667vw;
  -ms-grid-columns: 1fr 2.66667vw 1fr;
  grid-template-columns: repeat(2, 1fr);
}

@media screen and (min-width: 768px) {
  .anchor__list ul {
    margin-top: 2.08333vw;

    gap: 0.69444vw;
    -ms-grid-columns: 1fr 0.69444vw 1fr 0.69444vw 1fr 0.69444vw 1fr 0.69444vw 1fr;
    grid-template-columns: repeat(5, 1fr);
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list ul {
    margin-top: 30px;

    gap: 10px;
  }
}

.anchor__list .anchor__linkText {
  display: flex;
  align-items: center;
  position: relative;
  padding-left: 3.46667vw;
  border-radius: 0.53333vw;
  width: 100%;
  height: 26.66667vw;
  cursor: pointer;
  transition: background-color 0.45s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: rgba(213, 173, 88, 0.2);
  letter-spacing: 0.04em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText {
    padding-left: 1.38889vw;
    border-radius: clamp(1px,0.13889vw, 2px);
    height: 6.94444vw;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__linkText {
    padding-left: 20px;
    border-radius: 2px;
    height: 100px;
    font-size: 16px;
  }
}

.anchor__list .anchor__linkText .-arrow {
  overflow: hidden;
  position: absolute;
  top: initial;
  right: 3.46667vw;
  bottom: 4vw;
  width: 9.06667vw;
  height: 4px;
  -webkit-transform: initial;
          transform: initial;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText .-arrow {
    top: 50%;
    right: 0.69444vw;
    width: 2.36111vw;
    height: 0.27778vw;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__linkText .-arrow {
    right: 10px;
    width: 34px;
    height: 4px;
  }
}

.anchor__list .anchor__linkText .-arrow::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 9.06667vw;
  height: 4px;
  background-image: url(/assets/img/common/arw_mini_02.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText .-arrow::before {
    width: 2.36111vw;
    height: 0.27778vw;
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
    background-image: url(/assets/img/common/arw_02.svg);
    background-repeat: no-repeat;
    background-size: contain;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__linkText .-arrow::before {
    width: 34px;
    height: 4px;
  }
}

.anchor__list .anchor__linkText .-arrow::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 9.06667vw;
  height: 4px;
  background-image: url(/assets/img/common/arw_mini_01.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText .-arrow::after {
    width: 2.36111vw;
    height: 0.27778vw;
    background-image: url(/assets/img/common/arw_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__linkText .-arrow::after {
    width: 34px;
    height: 4px;
  }
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText:hover {
    background-color: #d5ad58;
    color: #fff;
  }
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText:hover .-arrow::before {
    transition: -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: 0.1s;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText:hover .-arrow::after {
    transition: -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.45s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translateX(110%);
            transform: translateX(110%);
  }
}

.anchor__list .anchor__linkText::before {
  display: flex;
  align-items: center;
  padding-left: 3.46667vw;
}

@media screen and (min-width: 768px) {
  .anchor__list .anchor__linkText::before {
    padding-left: 1.38889vw;
  }
}

@media screen and (min-width: 1440px) {
  .anchor__list .anchor__linkText::before {
    padding-left: 20px;
  }
}

/* ----------------------------------------------*
* system
*---------------------------------------------- */
.system {
  padding: 20vw 0 0;
}

@media screen and (min-width: 768px) {
  .system {
    padding-top: 13.88889vw;
  }
}

@media screen and (min-width: 1440px) {
  .system {
    padding-top: 200px;
  }
}

.system__img {
  margin-top: 10.66667vw;
  margin-left: auto;
  width: 94.66667vw;
}

@media screen and (min-width: 768px) {
  .system__img {
    margin-top: 0;
    margin-left: auto;
    width: 50.97222vw;
  }
}

@media screen and (min-width: 1440px) {
  .system__img {
    width: 734px;
  }
}

/* ----------------------------------------------*
* price
*---------------------------------------------- */
.price {
  padding: 17.33333vw 0 20vw;
}

@media screen and (min-width: 768px) {
  .price {
    padding-top: 13.88889vw;
    padding-bottom: 13.88889vw;
  }
}

@media screen and (min-width: 1440px) {
  .price {
    padding-top: 200px;
    padding-bottom: 200px;
  }
}

.price__img {
  margin-top: 10.66667vw;
  margin-right: auto;
  width: 94.66667vw;
}

@media screen and (min-width: 768px) {
  .price__img {
    margin-top: 0;
    margin-right: auto;
    width: 50.97222vw;
  }
}

@media screen and (min-width: 1440px) {
  .price__img {
    width: 734px;
  }
}

/* ----------------------------------------------*
* faq
*---------------------------------------------- */
.faq {
  padding: 20vw 0 29.33333vw;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .faq {
    padding-top: 13.88889vw;
    padding-bottom: 13.88889vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq {
    padding-top: 200px;
    padding-bottom: 200px;
  }
}

.faq__list {
  margin-left: auto;
}

@media screen and (max-width: 767px) {
  .faq__list {
    margin-top: 9.86667vw;
    padding: 0 5.33333vw;
  }
}

@media screen and (min-width: 768px) {
  .faq__list {
    width: 52.08333vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list {
    width: 750px;
  }
}

.faq__list__item__btn {
  display: flex;
  align-items: center;
  position: relative;
  border: 1px solid #e8e8e8;
  border-right: none;
  border-left: none;
  width: 100%;
  transition: background-color 0.21s cubic-bezier(0.215, 0.61, 0.355, 1);
  font-weight: normal;
}

.faq__list__item__btn a {
  display: inline-block;
  padding: 5.33333vw 2.66667vw;
  width: 100%;
  height: 100%;
  color: #d5ad58;
  font-size: 4.26667vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__btn a {
    padding: 2.43056vw 1.38889vw;
    font-size: 1.66667vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__btn a {
    padding: 35px 20px;
    font-size: 24px;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__btn:hover {
    transition: background-color 0.25s cubic-bezier(0.215, 0.61, 0.355, 1);
    background-color: #f9f9f9;
  }
}

.faq__list__item__btn::before,
.faq__list__item__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 3.2vw;
  width: 4.26667vw;
  height: 1px;
  transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  background-color: #999;
}

@media screen and (min-width: 768px) {
  .faq__list__item__btn::before,
  .faq__list__item__btn::after {
    right: 1.66667vw;
    width: 2.22222vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__btn::before,
  .faq__list__item__btn::after {
    right: 24px;
    width: 32px;
  }
}

.faq__list__item__btn::before {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

.faq__list__item__btn[aria-expanded="true"]::before {
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.faq__list__img {
  width: auto;
}

.faq__list__item + .faq__list__item {
  margin-top: -1px;
}

.faq__list__item__detail {
  display: flex;
  flex-flow: column;
  padding: 5.33333vw 2.66667vw;
  background-color: #f9f9f9;

  gap: 10.66667vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__detail {
    padding: 3.125vw;

    gap: 4.16667vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__detail {
    padding: 45px;

    gap: 60px;
  }
}

.faq__list__item__answer {
  display: flex;
  flex-flow: column;
  position: relative;

  gap: 1.86667vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer {
    gap: 0.69444vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer {
    gap: 10px;
  }
}

.faq__list__item__answer dt,
.faq__list__item__answer dd {
  display: flex;

  gap: 4vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt,
  .faq__list__item__answer dd {
    gap: 1.04167vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer dt,
  .faq__list__item__answer dd {
    gap: 15px;
  }
}

.faq__list__item__answer dt {
  font-size: 4vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt {
    font-size: 1.38889vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer dt {
    font-size: 20px;
  }
}

.faq__list__item__answer dt a {
  position: relative;
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a {
    text-decoration: none;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a::before {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: -0.13889vw;
    left: 0;
    margin: 0 auto;
    width: 100%;
    height: 1px;
    transition: -webkit-transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform-origin: left;
            transform-origin: left;
    background-color: #4d4d4d;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer dt a::before {
    bottom: -2px;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a::after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: -0.13889vw;
    left: 0;
    margin: 0 auto;
    width: 100%;
    height: 1px;
    transition: -webkit-transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.16s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: right;
            transform-origin: right;
    background-color: #d5ad58;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer dt a::after {
    bottom: -2px;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a:hover::before {
    transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: right;
            transform-origin: right;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a:hover::after {
    transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) 0.15s;
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) 0.15s;
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) 0.15s, -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1) 0.15s;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dt a:hover {
    transition: color 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    color: #d5ad58;
  }
}

.faq__list__item__answer dd {
  font-size: 3.73333vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer dd {
    font-size: 1.11111vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer dd {
    font-size: 16px;
  }
}

.faq__list__item__answer:not(:last-child)::before {
  content: "";
  position: absolute;
  bottom: -5.33333vw;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #e8e8e8;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer:not(:last-child)::before {
    bottom: -2.08333vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer:not(:last-child)::before {
    bottom: -30px;
  }
}

.faq__list__item__answer img {
  width: 6.4vw;
  height: 6.4vw;
}

@media screen and (min-width: 768px) {
  .faq__list__item__answer img {
    width: 2.22222vw;
    height: 2.22222vw;
  }
}

@media screen and (min-width: 1440px) {
  .faq__list__item__answer img {
    width: 32px;
    height: 32px;
  }
}

/* ----------------------------------------------*
* access
*---------------------------------------------- */
.access {
  padding: 17.33333vw 5.33333vw 21.33333vw;
}

@media screen and (min-width: 768px) {
  .access {
    padding: 13.88889vw 0 13.54167vw;
  }
}

@media screen and (min-width: 1440px) {
  .access {
    padding: 200px 0 195px;
  }
}

.access__imgWrapper {
  position: relative;
  margin-top: 10.66667vw;
  height: 58.66667vw;
}

@media screen and (min-width: 768px) {
  .access__imgWrapper {
    margin-top: 0;
    height: 39.58333vw;
  }
}

@media screen and (min-width: 1440px) {
  .access__imgWrapper {
    height: 570px;
  }
}

.access__img {
  position: absolute;
}

.access__img > span {
  display: block;
  position: absolute;
  margin: auto;

  inset: 0;
}

.access__img img {
  position: absolute;
  margin: auto;

  inset: 0;
}

.access__img.-top {
  top: 0;
  left: 0;
  width: 44.8vw;
  height: 48vw;
}

@media screen and (min-width: 768px) {
  .access__img.-top {
    width: 25.625vw;
    height: 27.5vw;
  }
}

@media screen and (min-width: 1440px) {
  .access__img.-top {
    width: 369px;
    height: 396px;
  }
}

.access__img.-bottom {
  right: 0;
  bottom: 0;
  width: 44.8vw;
  height: 48vw;
}

@media screen and (min-width: 768px) {
  .access__img.-bottom {
    right: auto;
    left: 25.625vw;
    width: 25.625vw;
    height: 27.5vw;
  }
}

@media screen and (min-width: 1440px) {
  .access__img.-bottom {
    left: 369px;
    width: 369px;
    height: 396px;
  }
}

.access__text {
  margin-top: 8vw;
  letter-spacing: 0.04em;
  font-size: 3.73333vw;
  line-height: 1.64286;
}

@media screen and (min-width: 768px) {
  .access__text {
    position: absolute;
    z-index: 1;
    top: 12.63889vw;
    left: 56.59722vw;
    margin-top: 0;
    font-size: 1.11111vw;
    line-height: 1.875;
  }
}

@media screen and (min-width: 1440px) {
  .access__text {
    top: 182px;
    left: 815px;
    font-size: 16px;
  }
}