@charset "utf-8";
/* スクロールアップ */

.scroll-up {
  opacity: 0;
  visibility: hidden;
  transform: translateY(2.6041666666666665vw); /* 50px */
  transition: all 1s;
}

.scroll-up.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0vw); /* 0px */
}

.poyo-in,
.scroll-fade {
  opacity: 0;
  transform: translateY(2vw);
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1), transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.poyo-in.scroll-in-visible,
.scroll-fade.scroll-in-visible {
  opacity: 1;
  transform: translateY(0);
}

.scroll-pop {
  opacity: 0;
  transform: scale(0.85) translateY(1.5vw);
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1), transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.scroll-pop.scroll-pop-visible {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/*基本設定*/
.row {
  flex-direction: row-reverse;
}

.pc-on{
  display: block;
}

.sp-on {
  display: none;
}

.pc-only{
  display: block;
}

.sp-only{
  display: none;
}

p {
  line-height: 2;
  font-style: normal;
  font-size: 0.7291666666666666vw; /* 14px */
  color: #000000;
}

img {
  width: 100%;
}

h2 {
  font-family: "Fascinate Inline", system-ui;
  font-weight: 400;
  font-style: normal;
  font-size: 3.4375vw; /* 66px */
  font-weight: bold;
  letter-spacing: 0.2604166666666667vw; /* 5px */
  text-align: center;
  will-change: transform;
}

.section-title {
  animation: none;
  transform-origin: left center;
}

.section-title .section-title-char {
  display: inline-block;
  opacity: 0;
  transform-origin: left center;
  transform: translateX(-3rem) rotate(-8deg) skewX(-8deg) scale(0.85);
  will-change: transform, opacity;
}

.section-title.scroll-in-visible .section-title-char {
  animation: sectionTitleWave 0.85s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: calc(var(--char-index, 0) * 0.07s);
}

.section-title .section-title-char[data-space="true"] {
  opacity: 1;
  transform: none;
  animation: none !important;
}

@keyframes sectionTitleWave {
  0% {
    opacity: 0;
    transform: translateX(-3rem) rotate(-8deg) skewX(-8deg) scale(0.85);
  }
  45% {
    opacity: 1;
    transform: translateX(0.9rem) rotate(6deg) skewX(6deg) scale(1.05);
  }
  70% {
    transform: translateX(-0.6rem) rotate(-4deg) skewX(-4deg) scale(0.97);
  }
  85% {
    transform: translateX(0.25rem) rotate(2deg) skewX(2deg) scale(1.02);
  }
  100% {
    opacity: 1;
    transform: translateX(0) rotate(0) skewX(0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .section-title {
    animation: none !important;
  }
  .section-title .section-title-char {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

.outlined-text {
  color: #fb3f3f;
  text-shadow:
    -0.15625vw -0.15625vw 0 #fff, /* -3px -3px */
     0vw -0.15625vw 0 #fff,       /* 0px -3px */
     0.15625vw -0.15625vw 0 #fff, /* 3px -3px */
    -0.15625vw  0vw 0 #fff,       /* -3px 0px */
     0.15625vw  0vw 0 #fff,       /* 3px 0px */
    -0.15625vw  0.15625vw 0 #fff, /* -3px 3px */
     0vw  0.15625vw 0 #fff,       /* 0px 3px */
     0.15625vw  0.15625vw 0 #fff; /* 3px 3px */
}

body {
  width: 100%;
  height: 100%;
  margin: auto;
  color: #000;
  word-wrap: break-word;
  overflow-wrap: break-word;
  overflow-x: hidden;
  font-family: "toppan-bunkyu-midashi-go-std", sans-serif;
  font-weight: 900;
  font-style: normal;
  font-weight: 900;
  font-style: normal;
  font-style: normal;
  letter-spacing: 0.2604166666666667vw; /* 5px */
  font-weight: normal;
}

.YuGothic {
  font-family: "Yu Gothic", "游ゴシック体", "YuGothic", sans-serif;
  letter-spacing: 0.10416666666666667vw; /* 2px */
}

li {
  list-style: none;
}

.sp-br {
  display: none;
}

.pc-br {
  display: block;
}

/*画像ズーム*/
.moimg1 {
  overflow: hidden;
  border-radius: 2.6041666666666665vw; /* 50px */
}

.moimg2 {
  overflow: hidden;
}

.moimg1 img,
.moimg2 img {
  display: block;
  transition: 0.5s;
}
.moimg1 img:hover,
.moimg2 img:hover {
  transform: scale(1.1, 1.1);
}

.zoom-in {
  display: block;
  transition: 0.5s;
}

.zoom-in:hover {
  transform: scale(1.1, 1.1);
}
/* 画像ズームここまで */

#fv {
  position: relative;
  width: 100%;
  height: 41.666666666666664vw; /* 800px */
  overflow: hidden;
  z-index: 1;
}

/* グレー影（下） */
.fv-shadow {
  position: absolute;
  inset: 0;
  transform: translateY(0.3125vw); /* 6px */
  z-index: 0;
  width: 100%;
  height: 99%;
  pointer-events: none;
}

/* 背景画像（上） */
.fv-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 97%;
  z-index: 1;
}

.fv-bg image{
  display: block;
  width: 100%;
}

/* 中央のテキスト */
.fv-inner {
  position: relative;
  z-index: 2;
  height: 100%;
  width: 41.666666666666664vw; /* 800px */
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.bg-image {
  width: 62.5vw; /* 1200px */
  height: auto;
}

/* テキスト画像（重ねる方） */
.text-overlay-1 {
  position: absolute;
  top: 41%;
  left: 47%;
  transform: translate(-50%, -50%);
  width: 41.6875vw; /* 800px */
  pointer-events: none;
  animation: poyoPop 0.9s cubic-bezier(0.22, 1.28, 0.58, 1) 0.1s both;
}

.text-overlay-2 {
  position: absolute;
  top: 65%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 26.041666666666668vw; /* 500px */
  pointer-events: none;
  animation: poyoPop 0.9s cubic-bezier(0.22, 1.28, 0.58, 1) 0.25s both;
}

.text-overlay-3 {
  position: absolute;
  top: 72%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 23.4375vw; /* 450px */
  pointer-events: none;
  animation: poyoPop 0.9s cubic-bezier(0.22, 1.28, 0.58, 1) 0.4s both;
}

.text-overlay-4 {
  position: absolute;
  top: 20%;
  left: -8%;
  transform: translate(-50%, -50%);
  width: 13.020833333333334vw; /* 250px */
  pointer-events: none;
  animation: swirlSlide 1.1s cubic-bezier(0.23, 1.17, 0.58, 1) 0.55s both;
}

.text-overlay-5 {
  position: absolute;
  bottom: -28%;
  right: -32%;
  transform: translate(-50%, -50%);
  width: 12.239583333333334vw; /* 235px */
  animation: poyoPop 0.9s cubic-bezier(0.22, 1.28, 0.58, 1) 0.7s both;
}

.text-overlay-1,
.text-overlay-2,
.text-overlay-3,
.text-overlay-4,
.text-overlay-5{
  opacity: 0;
}

@keyframes poyoPop{
  0%{
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.4);
  }
  55%{
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.15);
  }
  75%{
    transform: translate(-50%, -50%) scale(0.92);
  }
  100%{
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

@keyframes swirlSlide{
  0%{
    opacity: 0;
    transform: translate(-240%, -50%) rotate(-260deg) scale(0.2);
    filter: blur(12px);
  }
  50%{
    opacity: 1;
    transform: translate(-70%, -60%) rotate(35deg) scale(1.1);
    filter: blur(0);
  }
  80%{
    transform: translate(-40%, -48%) rotate(-10deg) scale(0.95);
  }
  100%{
    opacity: 1;
    transform: translate(-50%, -50%) rotate(0deg) scale(1);
  }
}

.logo {
  position: absolute;
  width: 8.854166666666666vw; /* 170px */
  z-index: 2;
  margin: 1.0416666666666667vw 0 0 1.0416666666666667vw; /* 20px */
}

.fv-btn {
  width: 65%;
  position: absolute;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #ffd900;
  color: #19488d;
  border-radius: 1.5625vw; /* 30px */
  border: solid 0.15625vw #19488d; /* 3px */
  padding: 0.78125vw 1.0416666666666667vw; /* 15px 20px */
  font-weight: bold;
  font-size: 1.3541666666666667vw; /* 26px */
  letter-spacing: 0.15625vw; /* 3px */
  text-align: center;
}

.fv-btn:before {
  display: block;
  content: "";
  position: absolute;
  background: url(../img/arrow-2.png) no-repeat;
  background-size: contain;
  top: 35%;
  left: auto;
  width: 2.6041666666666665vw; /* 50px */
  height: 0.8333333333333334vw; /* 16px */
  right: 0vw; /* 0px */
  z-index: 1000;
  transform: translateX(0);
  transition: transform 0.4s ease;
}

.fv-btn:hover::before {
  transform: translateX(0.5208333333333334vw); /* 10px */
}

.fv-btn a {
  display: block;
}

section {
  padding: 10.416666666666668vw 7.8125vw; /* 200px 15% */
}

.section-title {
  margin-bottom: 2.6041666666666665vw; /* 50px */
}

.problem-area {
  background-image: url(../img/bg-01.jpg);
  background-size: 100% auto;
  margin-top: -10.416666666666668vw; /* -200px */
  padding: 13.020833333333334vw; /* 250px */
}

.intro-text {
  text-align: center;
  position: relative;
  width: 36.458333333333336vw; /* 700px */
  margin: 0 auto;
  line-height: 2;
}

.intro-text h4 {
  font-size: 1.25vw; /* 24px */
}

.intro-text h3 {
  font-size: 1.7708333333333333vw; /* 34px */
}

.intro-text::before,
.intro-text::after {
  content: "";
  position: absolute;
  top: 0;
  width: 1.6666666666666667vw; /* 32px */
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  pointer-events: none;
}

.intro-text::before {
  left: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/kakukakko-l.png");
}

.intro-text::after {
  right: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/kakukakko-r.png");
}

.balloon-wrap {
  position: relative;
  margin: 0 auto;
  text-align: center;
  margin-top: 5.208333333333334vw; /* 100px */
}

/* 右上イラスト */
.balloon-wrap::after {
  content: "";
  background-image: url(../img/img-01.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 14.583333333333334vw; /* 280px */
  height: 14.583333333333334vw; /* 280px */
  top: -7.8125vw; /* -150px */
  right: -7.8125vw; /* -150px ※ここ修正 */
  animation: balloonFloat 4.5s ease-in-out infinite;
}

@keyframes balloonFloat {
  0% {
    transform: translateY(0) rotate(-1deg);
  }
  50% {
    transform: translateY(-1.0416666666666667vw) rotate(2deg); /* 約-20px */
  }
  100% {
    transform: translateY(0) rotate(-1deg);
  }
}

/* 左下イラスト */
.balloon-wrap::before {
  content: "";
  background-image: url(../img/img-02.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  width: 14.583333333333334vw; /* 280px */
  height: 14.583333333333334vw; /* 280px */
  bottom: 5.1875vw; /* 99.6px */
  left: -7.8125vw; /* -150px */
  animation: balloonFloat 4.5s ease-in-out infinite;
}

.balloon-r {
  position: relative;
  display: inline-block;
  background: #19488d;
  color: #fff;
  padding: 1.0416666666666667vw; /* 20px */
  border-radius: 5.208333333333334vw; /* 100px */
  box-shadow: 0.4166666666666667vw 0.4166666666666667vw 0vw rgba(0, 0, 0); /* 8px 8px 0px */
  width: 41.0625vw;
  text-align: center;
  margin-bottom: 2.6041666666666665vw; /* 50px */
}

.balloon-r::after {
  content: "";
  position: absolute;
  top: 27%;
  right: -0.6770833333333334vw; /* -13px */
  transform: translateY(-50%) rotate(-26deg);
  width: 0;
  height: 0;
  border-top: 0.4166666666666667vw solid transparent; /* 8px */
  border-bottom: 0.78125vw solid transparent; /* 15px */
  border-left: 1.1458333333333333vw solid #19488d; /* 22px */
}

.balloon-l {
  position: relative;
  display: inline-block;
  background: #19488d;
  color: #fff;
  padding: 1.0416666666666667vw; /* 20px */
  border-radius: 5.208333333333334vw; /* 100px */
  box-shadow: 0.4166666666666667vw 0.4166666666666667vw 0vw rgba(0, 0, 0); /* 8px 8px 0px */
  width: 41.0625vw;
  text-align: center;
  margin-bottom: 2.6041666666666665vw; /* 50px */
}

.balloon-l::after {
  content: "";
  position: absolute;
  top: 27%;
  left: -0.6770833333333334vw; /* -13px */
  transform: translateY(-50%) rotate(26deg);
  width: 0;
  height: 0;
  border-top: 0.4166666666666667vw solid transparent; /* 8px */
  border-bottom: 0.78125vw solid transparent; /* 15px */
  border-right: 1.1458333333333333vw solid #19488d; /* 22px */
}

.balloon-text {
  color: #fff;
  font-size: 1.4583333333333333vw; /* 28px */
}

.arrow {
  width: 2.6041666666666665vw; /* 50px */
  margin: 0 auto;
  padding-top: 2.6041666666666665vw; /* 50px */
  animation: arrowFloat 2.4s ease-in-out infinite;
}

.arrow img {
  display: block;
  width: 100%;
  height: auto;
}

@keyframes arrowFloat {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-0.5208333333333334vw); /* -10px */
  }
  100% {
    transform: translateY(0);
  }
}

.solution-catch {
  position: relative;
  text-align: center;
  font-weight: 800;
  font-size: 1.7708333333333333vw; /* 34px */
  width: 36.458333333333336vw; /* 700px */
  margin: 0 auto;
  padding: 5.208333333333334vw 0; /* 100px 0 */
}

.solution-catch .marker {
  display: inline;
  padding: 0 0.2em;
  background: linear-gradient(transparent 60%, #ffff00 60%);
}

.solution-catch::before,
.solution-catch::after {
  content: "";
  position: absolute;
  top: 1.5625vw; /* 30px */
  width: 6.666667vw;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  pointer-events: none;
}

.solution-catch::before {
  left: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/slash-l.png");
}

.solution-catch::after {
  right: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/slash-r.png");
}

.balloon-feature {
  position: relative;
  width: 41.666666666666664vw; /* 800px */
  margin: 0 auto;
  padding-top: 2.6041666666666665vw; /* 50px */
}

.eye {
  position: absolute;
  width: 9.895833333333334vw; /* 190px */
  left: 0;
  right: 0;
  margin: 0 auto;
  top: 1.5625vw; /* 30px */
  animation: eyeWiggle 1.2s ease-in-out infinite;
}

.eye-2 {
  position: absolute;
  width: 3.6458333333333335vw; /* 70px */
  left: 0;
  right: 0;
  margin: 0 auto;
  top: -1.0416666666666667vw; /* -20px */
  animation: eyeWiggle 1.2s ease-in-out infinite;
}

.digital-kanpe {
  padding-top: 2.6041666666666665vw; /* 50px */
  opacity: 0;
  transform: scale(0.8) translateY(1.5vw);
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1), transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

.digital-kanpe.scroll-pop-visible {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.btn {
  position: relative;
  width: 31%;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #ffd900;
  color: #19488d;
  border-radius: 1.5625vw; /* 30px */
  border: solid 0.15625vw #19488d; /* 3px */
  padding: 0.78125vw 1.0416666666666667vw; /* 15px 20px */
  font-weight: bold;
  font-size: 1.5625vw; /* 30px */
  letter-spacing: 0.15625vw; /* 3px */
  text-align: center;
}

.btn:before {
  position: absolute;
  display: block;
  content: "";
  background: url(../img/arrow-2.png) no-repeat;
  background-size: contain;
  top: 35%;
  left: auto;
  width: 2.6041666666666665vw; /* 50px */
  height: 0.8333333333333334vw; /* 16px */
  right: 0vw; /* 0px */
  z-index: 1000;
  transform: translateX(0);
  transition: transform 0.4s ease;
}

.btn:hover::before {
  transform: translateX(0.5208333333333334vw); /* 10px */
}

.btn a {
  display: block;
}

.contact-area .eye {
  position: absolute;
  width: 3.125vw; /* 60px */
  top: -0.78125vw; /* -15px */
}

.contact-area .eye-2 {
  animation: eyeWiggle 1.2s ease-in-out infinite;
}

.btn:hover .eye {
  animation: eyeWiggle 0.8s ease-in-out infinite;
}

.btn-2:hover .eye-2 {
  animation: eyeWiggle 0.8s ease-in-out infinite;
}

@keyframes eyeWiggle {
  0% {
    transform: rotate(0deg);
  }
  30% {
    transform: rotate(-6deg) translateX(-0.15625vw);
  }
  60% {
    transform: rotate(6deg) translateX(0.15625vw);
  }
  100% {
    transform: rotate(0deg);
  }
}

.contact-area .logo {
  display: block;
  position: static;
  width: 12.5vw;
  margin: 2.0833333333333335vw auto 0; /* 40px */
}

.contact-text {
  width: 20.833333333333332vw; /* 400px */
  margin: 0 auto;
  margin-bottom: 2.6041666666666665vw; /* 50px */
}

section.contact-area {
  padding: 2.6041666666666665vw; /* 50px */
}

section.contact-area:last-of-type {
  background-color: #19488d;
}

.contact-area-2 .eye {
  position: absolute;
  width: 3.125vw; /* 60px */
  top: -0.78125vw; /* -15px */
}

section.contact-area-2 {
  padding: 2.6041666666666665vw; /* 50px */
  margin-top: 5.208333333333334vw; /* 100px */
}

.btn-2 {
  position: relative;
  width: 35%;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #19488d;
  color: #ffd900;
  border-radius: 1.5625vw; /* 30px */
  border: solid 0.15625vw #fff; /* 3px */
  padding: 0.78125vw 1.0416666666666667vw; /* 15px 20px */
  font-weight: bold;
  font-size: 1.5625vw; /* 30px */
  letter-spacing: 0.15625vw; /* 3px */
  text-align: center;
}

.btn-2:before {
  position: absolute;
  display: block;
  content: "";
  background: url(../img/arrow-4.png) no-repeat;
  background-size: contain;
  top: 35%;
  left: auto;
  width: 2.6041666666666665vw; /* 50px */
  height: 0.8333333333333334vw; /* 16px */
  right: 0vw; /* 0px */
  z-index: 1000;
  transform: translateX(0);
  transition: transform 0.4s ease;
}

.btn-2:hover::before {
  transform: translateX(0.5208333333333334vw); /* 10px */
}

.reason-area {
  background-image: url(../img/bg-02.jpg);
  background-size: 100% auto;
}

.section-title > span:not(.section-title-char) {
  display: block;
  color: #fff;
  text-shadow: none;
  font-family: "toppan-bunkyu-midashi-go-std", sans-serif;
  font-weight: 900;
  font-style: normal;
  font-size: 1.7708333333333333vw; /* 34px */
  margin-top: 1.0416666666666667vw; /* 20px */
}

.reason-area .intro-text {
  color: #fff;
  width: 40.458333vw;
  line-height: 2;
}

.reason-area .intro-text::before,
.reason-area .intro-text::after {
  content: "";
  position: absolute;
  top: 0;
  width: 1.6666666666666667vw; /* 32px */
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  pointer-events: none;
}

.reason-area .intro-text::before {
  left: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/kakukakko-l-2.png");
}

.reason-area .intro-text::after {
  right: -0.5208333333333334vw; /* -10px */
  background-image: url("../img/kakukakko-r-2.png");
}

.intro-text h4 {
  font-size: 0.8854166666666666vw; /* 17px */
}

.reason-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 1.5625vw; /* 30px */
  row-gap: 5.208333333333334vw; /* 100px */
  margin-top: 5.208333333333334vw; /* 100px */
}

.reason-list ul {
  width: 26%;
  position: relative;
}

.tab-switch label:first-of-type {
  border-top-left-radius: 1.0416666666666667vw; /* 20px */
  border-bottom-left-radius: 1.0416666666666667vw; /* 20px */
}

.tab-switch label:last-of-type {
  border-top-right-radius: 1.0416666666666667vw; /* 20px */
  border-bottom-right-radius: 1.0416666666666667vw; /* 20px */
}

.reason-list .point-box {
  background-color: #fff3d2;
  border-radius: 1.5625vw; /* 30px */
  padding: 4.6875vw 2.04167vw 2.6041666666666665vw;
  margin-top: 1.0416666666666667vw; /* 20px */
}

.reason-list ul .point-box img {
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
}

.reason-list ul:nth-of-type(1) .point-box img:nth-child(1) {
  width: 13.416667vw;
  top: -0.677083vw;
  left: 1.8229166666666667vw;
  right: 0;
  margin: auto;
}

.reason-list ul:nth-of-type(2) .point-box img:nth-child(1) {
  width: 10.458333vw;
  top: -0.6770833333333334vw; /* -13px */
}

.reason-list ul:nth-of-type(3) .point-box img:nth-child(1) {
  width: 10.458333vw;
  top: -1.4583333333333333vw; /* -28px */
}

.reason-list ul:nth-of-type(4) .point-box img:nth-child(1) {
  width: 8.458333vw;
  top: 0vw; /* 0px */
}

.reason-list ul:nth-of-type(5) .point-box img:nth-child(1) {
  width: 7.458333vw;
  top: 0.2604166666666667vw; /* 5px */
}

.reason-list ul .point-box h3 {
  font-size: 1.0416666666666667vw; /* 20px */
  color: #19488d;
  margin-bottom: 0.5208333333333334vw; /* 10px */
  text-align: center;
}

.point-box p.YuGothic {
  font-weight: normal;
  font-size: 0.8854166666666666vw; /* 17px */
}

.window {
  width: 50%;
  margin: 0 auto;
  padding-top: 5.208333333333334vw; /* 100px */
  padding-bottom: 2.6041666666666665vw; /* 50px */
}

.check-list {
  display: flex;
  justify-content: center;
  gap: 5.208333333333334vw; /* 100px */
  font-size: 1.0416666666666667vw;
  color: #fff;
  line-height: 2;
  padding-bottom: 5.208333333333334vw; /* 100px */
}

.check-list ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.check-list li {
  position: relative;
  padding-left: 2.34375vw; /* 45px */
}

.check-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1.1458333333333333vw; /* 22px */
  height: 1.1458333333333333vw; /* 22px */
  background: url(../img/check.png) no-repeat center/contain;
}

.check-list ul:last-child li:last-child::before {
  display: none;
}

.t-reason {
  text-align: center;
  color: #fff;
  padding: 2.6041666666666665vw 0; /* 50px */
  width: 50%;
  border-bottom: 0.15625vw solid; /* 3px */
  border-top: 0.15625vw solid; /* 3px */
  margin: 0 auto;
}

.t-reason h3 {
  font-size: 1.7708333333333333vw;
}

.t-reason p {
  color: #fff;
  padding-top: 1.0416666666666667vw; /* 20px */
  font-size: 0.8854166666666666vw;
}

.baf-area {
  background-image: url(../img/bg-03.jpg);
  background-size: 100% auto;
}

.baf-area .section-title > span:not(.section-title-char) {
  color: black;
}

.baf-area .intro-text::before {
  left: -2.520833vw;
}

.baf-area .intro-text::after {
  right: -2.520833vw;
}

.baf-list {
  margin-top: 5.208333333333334vw; /* 100px */
  margin-bottom: 5.208333333333334vw; /* 100px */
  display: flex;
  justify-content: center;
  gap: 2.5vw; /* 48px */
  flex-wrap: wrap;
}

.baf-arrow {
  width: 3vw;
  min-width: 3.125vw; /* 60px */
  display: flex;
  justify-content: center;
  align-items: center;
  align-self: stretch;
}

.baf-arrow img {
  width: 100%;
  height: auto;
}

.baf-card {
  position: relative;
  background-color: #ffd900;
  border-radius: 2.6041666666666665vw; /* 50px */
  padding: 3.125vw; /* 60px */
  padding-bottom: 7.8125vw; /* 150px */
  width: 40%;
  min-width: 15.625vw; /* 300px */
}

.baf-card .baf-label {
  text-align: center;
  font-size: 2.9166666666666665vw;
  letter-spacing: 0.2em;
  color: #ec6300;
  margin-bottom: 1.083333vw;
  font-family: "Fascinate Inline", system-ui;
}

.baf-card.after-card {
  background-color: #19488d;
  color: #fff;
}

.baf-card.after-card .baf-label {
  color: #c5dfff;
}

.baf-points {
  list-style: none;
  margin: 0;
  padding: 0;
  color: #111;
  font-weight: 600;
  font-size: 1.0416666666666667vw;
  line-height: 1.9;
}

.baf-points li {
  position: relative;
  padding-left: 1.7708333333333333vw; /* 34px */
  font-size: 0.8854166666666666vw;
}

.baf-points li::before {
  content: "";
  position: absolute;
  width: 0.625vw; /* 12px */
  height: 0.625vw; /* 12px */
  border-radius: 50%;
  background-color: #222;
  left: 0;
  top: 0.98em;
  transform: translateY(-50%);
}

.baf-points li + li {
  margin-top: 0.8333333333333334vw; /* 16px */
}

.after-card .baf-points {
  color: #fff;
}

.after-card .baf-points li::before {
  background-color: #c5dfff;
}

.baf-points li.baf-illast {
  position: absolute;
  width: 20.833333333333332vw; /* 400px */
  left: 4.791666666666667vw; /* 92px */
  right: 0;
  bottom: -5.395833vw;
  margin: 0 auto;
  padding-left: 0;
}

.baf-points li.baf-illast::before {
  display: none;
}

.after-card .baf-points li.baf-illast {
  width: 18.666667vw;
  left: -0.75vw;
}

.tab-switch {
  --tab-color: #000;
  display: flex;
  flex-wrap: wrap;
  width: 85%;
  margin-inline: auto;
  background-color: #fff;
  border-radius: 1.3020833333333333vw; /* 25px */
  border: 0.052083333333333336vw solid rgba(0, 0, 0, 0.08); /* 1px */
  box-shadow: 0 1.0416666666666667vw 2.34375vw rgba(0, 0, 0, 0.1); /* 0 20px 45px */
}

/* タブボタン */
.tab-switch label {
  padding: 1.0416666666666667vw; /* 20px */
  background: #000;
  color: #fff;
  cursor: pointer;
  order: -1; /* 上に表示 */
  text-align: center;
  flex: 1; /* 均等幅 */
  min-width: 3.125vw; /* 60px */
  position: relative;
}

/* ラジオ非表示 */
.tab-switch input {
  display: none;
}

/* コンテンツ非表示 */
.tab-content {
  display: none;
  width: 100%;
  padding: 2.6041666666666665vw; /* 50px */
  box-sizing: border-box;
  overflow: hidden;
}

/* 選択されたタブ＋コンテンツ表示 */
.tab-switch label:has(:checked) {
  background: var(--tab-color);
  color: #ffd900;
}
.tab-switch label:has(:checked) + .tab-content {
  display: block;
}

/* 吹き出し */
.tab-switch label:has(:checked)::before {
  content: "";
  position: absolute;
  top: calc(100% - 0.052083333333333336vw); /* 1px */
  left: 50%;
  transform: translateX(-50%);
  width: 0.9375vw; /* 18px */
  height: 0.46875vw; /* 9px */
  background-color: var(--tab-color);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  z-index: 1;
}

.tab-content ul {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 1.0416666666666667vw; /* 20px */
  flex-wrap: nowrap;
}

.tab-content > ul:first-of-type {
  width: 65%;
  margin: 0 auto;
}

.tab-content ul li {
  flex: 1 1 45%;
}

.tab-content ul li:first-child {
  flex: 0 1 75%;
}

.tab-content ul li:last-child {
  flex: 1 1 55%;
}

.tab-content ul li img {
  width: 100%;
  height: auto;
  display: block;
}

.tab-content h4 {
  color: #19488d;
  font-size: 1.0416666666666667vw;
  display: flex;
  align-items: center;
  padding-bottom: 0.5208333333333334vw; /* 10px */
}

.tab-content h4::before {
  content: "●";
  color: #19488d;
  font-size: 0.9em;
}

.tab-content p {
  font-size: 0.8854166666666666vw;
}

.equipment-table {
  margin-top: 2.0833333333333335vw; /* 40px */
  font-size: 0.8854166666666666vw;
  font-weight: 600;
  width: 100%;
  text-align: center;
}

.equipment-table-header,
.equipment-table-body li {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.0416666666666667vw;
  width: 100%;
}

.equipment-table-header:has(span:nth-child(3)),
.equipment-table-body li:has(span:nth-child(3)) {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.equipment-table-header:has(span:nth-child(4)),
.equipment-table-body li:has(span:nth-child(4)) {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.equipment-table-header span,
.equipment-table-body li span {
  display: block;
  padding: 1.0416666666666667vw 0; /* 20px */
  border-bottom: 0.052083333333333336vw solid rgba(0, 0, 0, 0.12); /* 1px */
}

.equipment-table-header span {
  letter-spacing: 0.12em;
  font-size: 1.0416666666666667vw;
  border-bottom: 0.10416666666666667vw solid rgba(0, 0, 0, 0.25); /* 2px */
}

.equipment-table-body {
  list-style: none;
  margin: 0;
  padding: 0;
}

.equipment-table-body li + li {
  margin-top: 0.4166666666666667vw; /* 8px */
}

.equipment-table-body li span:nth-child(1),
.equipment-table-body li span:nth-child(2) {
  letter-spacing: 0.05em;
}

.flow-area {
  background-image: url(../img/bg-04.jpg);
  background-size: cover;
  padding-bottom: 31.25vw; /* 600px */
}

.flow-area .section-title > span:not(.section-title-char) {
  color: black;
}

.flow-list {
  display: flex;
  justify-content: center;
  gap: 2.6041666666666665vw; /* 50px */
  row-gap: 5.208333333333334vw; /* 100px */
  width: 88%;
  margin: 0 auto;
  padding-top: 5.208333333333334vw; /* 100px */
  flex-wrap: wrap;
  padding-bottom: 10.416666666666668vw; /* 200px */
}

.flow-list ul {
  width: 25%;
}

.flow-list ul:nth-of-type(4) {
  width: 28%;
}

.flow-title {
  font-size: 1.0416666666666667vw;
  color: #ffd900;
  background-color: #19488d;
  text-align: center;
  padding: 1.5625vw; /* 30px */
  position: relative;
  overflow: visible;
}

.flow-list ul:first-of-type .flow-title {
  padding: 1.5625vw 1.5625vw 1.5625vw 4.5625vw;
}

.flow-title img {
  position: absolute;
  width: 4.166666666666667vw; /* 80px */
  left: 0;
  top: -2.34375vw; /* -45px */
}

.flow-title::after {
  content: "";
  position: absolute;
  top: 0;
  right: -2.58vw;
  width: 2.6041666666666665vw; /* 50px */
  height: 100%;
  background-color: #19488d;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  border-top-right-radius: 0.4166666666666667vw; /* 8px */
  border-bottom-right-radius: 0.4166666666666667vw; /* 8px */
}

.flow-list ul:not(:first-of-type) .flow-title {
  padding: 1.5625vw 2.6041666666666665vw 1.5625vw 5.645833vw;
}

.flow-list ul:not(:first-of-type) .flow-title::before {
  content: "";
  position: absolute;
  top: 0;
  left: -0.10416666666666667vw; /* -2px */
  width: 2.0833333333333335vw; /* 40px */
  height: 100%;
  background-color: #ffd900;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  border-top-left-radius: 0.4166666666666667vw; /* 8px */
  border-bottom-left-radius: 0.4166666666666667vw; /* 8px */
}

.flow-icon {
  padding: 1.5625vw 0; /* 30px */
  width: 55%;
  margin: 0 auto;
}

.flow-text {
  font-size: 0.8854166666666666vw;
  width: 80%;
  margin: 0 auto;
  line-height: 2;
}

.faq-list {
  padding-top: 2.6041666666666665vw; /* 50px */
  display: flex;
  flex-direction: column;
  gap: 2.5625vw;
}

.faq-item {
  overflow: hidden;
}

.faq-question {
  background-color: #fff;
  border-radius: 2.6041666666666665vw; /* 50px */
  width: 100%;
  border: none;
  padding: 1.5625vw 3.125vw; /* 30px 60px */
  display: flex;
  align-items: center;
  gap: 1.0416666666666667vw; /* 20px */
  font-size: 1.0416666666666667vw;
  font-weight: 700;
  cursor: pointer;
  position: relative;
}

.faq-question:focus-visible {
  outline: 0.15625vw solid #ffd900; /* 3px */
  outline-offset: 0.15625vw; /* 3px */
  border-radius: 2.6041666666666665vw; /* 50px */
}

.faq-label {
  color: #19488d;
  font-weight: 700;
}

.faq-text {
  flex: 1;
  text-align: left;
  color: #111;
}

.faq-toggle {
  width: 1.25vw; /* 24px */
  height: 1.25vw; /* 24px */
  position: relative;
}

.faq-toggle::before,
.faq-toggle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.9375vw; /* 18px */
  height: 0.10416666666666667vw; /* 2px */
  background-color: #19488d;
  transform: translate(-50%, -50%);
  transition: transform 0.2s ease;
}

.faq-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.faq-question[aria-expanded="true"] .faq-toggle::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.faq-answer {
  padding: 0 2.0833333333333335vw 0 4.427083333333333vw; /* 0 40px 0 85px */
  color: #111;
  line-height: 1.9;
  margin-top: 1.0416666666666667vw; /* 20px */
  overflow: hidden;
  height: 0;
  opacity: 0;
  transition: height 0.35s ease, opacity 0.3s ease;
  will-change: height, opacity;
}

.faq-answer.is-open {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .faq-answer {
    transition: none;
  }
}

.faq-area {
  position: relative;
  width: 75%;
  margin: 0 auto;
  background-color: #fff3d2;
  border-radius: 2.6041666666666665vw; /* 50px */
  padding: 9.375vw; /* 180px */
  margin-bottom: 10.416666666666668vw; /* 200px */
}

.faq-area:before {
  content: "";
  position: absolute;
  left: auto;
  right: 1.3020833333333333vw; /* 25px */
  margin: auto;
  top: -3%;
  transform: translateY(-50%);
  width: 18.229166666666668vw; /* 350px */
  height: 18.229166666666668vw; /* 350px */
  background: url(../img/illast-08.png) no-repeat center/contain;
}

.footer {
  position: relative;
  background-color: #19488d;
  padding-bottom: 2.6041666666666665vw; /* 50px */
}

.footer .window {
  position: absolute;
  margin: auto;
  left: 0;
  right: 0;
  top: -31.25vw; /* -600px */
}

.footer .t-reason {
  margin-top: 18.229166666666668vw; /* 350px */
}

/*スマホ*/
@media screen and (max-width: 768px){
  html{
    width:100%;
    overflow-x:hidden;
  }

  .fv-bg image.pc-only{display:none;}
  .fv-bg image.sp-only{display:block;}
  .fv-bg image.sp-only{display:none;}

  .en-2{font-family:'Tilt Warp',cursive;}
  .en{font-family:'Montserrat',sans-serif;font-weight:300;}

  h2{font-size:8.636vw;}
  p{font-size:1rem;}

  .pc-on,.pc-only,.pc-br{display:none!important;}
  .sp-on,.sp-only,.sp-br{display:block!important;}

  body{overflow-x:hidden;}

  section{padding:22.727vw 4.545vw;}
  .logo{width:18.182vw;}

  #fv{
    position:static;
    height:auto;
    padding:2.273vw 0 0;
  }

  .fv-bg{height:-webkit-fill-available;}

  .fv-inner{
    width:92%;
    flex-direction:column;
    gap:4.545vw;
    margin-top: 6.818vw;
  }

  .bg-image{width:100%;}
  .bg-image.pc-only{display:block;}
  .bg-image.sp-only{display:none;}

  .text-overlay-1{
    top:39%;
    left:47%;
    width:68.182vw;
  }

  .text-overlay-2{
    top:60%;
    left:47%;
    width: 61.545vw;
  }

  .text-overlay-3{
    top:68%;
    left:50%;
    width:57vw;
  }

  .text-overlay-4{
    top:15%;
    left:auto;
    right:-4.545vw;
    width:22.727vw;
  }

  .text-overlay-5{
    width:23.409vw;
    right:-15.909vw;
    left:auto;
    bottom:-22.727vw;
  }

  .fv-btn{
    width:75%;
    top:76%;
    border-radius:4.545vw;
    font-size:3.864vw;
    padding: 1.78125vw 1.0416666666666667vw;
  }

  .fv-btn:before{
    width:2.273vw;
    height:2.273vw;
    right:2.273vw;
  }

  .problem-area{
    margin-top:0;
    padding:45.455vw 4.545vw 22.727vw;
    background-size:cover;
    margin-top:-22.727vw;
  }

  .intro-text{width:100%;}

  .intro-text::before,
  .intro-text::after{
    display:block;
    width:5.455vw;
    height:90%;
    top:5%;
  }

  .intro-text::before{left:1.136vw;}
  .intro-text::after{right:-1.136vw;}

  .balloon-wrap{margin-top:5.682vw;}

  .balloon-r,
  .balloon-l{
    width:100%;
    padding:2.273vw 4.545vw;
    border-radius:9.091vw;
    box-shadow: 0.916667vw 0.916667vw 0vw rgba(0, 0, 0);
  }

  .balloon-text{font-size:3.182vw;}


  .balloon-wrap::after{
    width: 27.273vw;
height: 27.273vw;
top: -56.818vw;
right: -4.545vw;
  }

  .balloon-wrap::before{
    width: 27.273vw;
    height: 27.273vw;
bottom: -29.545vw;
  }

  .balloon-r::after{
    right:-1.136vw;
    top:4.545vw;
    transform:translateY(-76%) rotate(-35deg);
    border-top:2.5vw solid transparent;
    border-bottom:1.591vw solid transparent;
    border-left:3.409vw solid #19488d;
  }

  .balloon-l::after{
    right:-1.136vw;
    top:4.545vw;
    transform:translateY(-76%) rotate(-35deg);
    border-top:2.5vw solid transparent;
    border-bottom:1.591vw solid transparent;
    border-left:3.409vw solid #19488d;
  }

  .solution-catch::before,
  .solution-catch::after{
    top:2.273vw;
    width:11.364vw;
  }

  .solution-catch::before{left:3.364vw;}
  .solution-catch::after{right:3.364vw;}

  .arrow{
    width:9.091vw;
    padding-top:15.818vw;
  }

  .solution-catch{
    width:100%;
    font-size:4.773vw;
    padding: 14.364vw 0;
  }

  .balloon-feature{
    width:100%;
    display:flex;
    flex-direction:column;
    gap:6.818vw;
    align-items:center;
  }

  .eye{width:18.182vw;}

  .reason-list ul{
    flex-direction:column;
    width:100%;
  }

  .baf-card{width:100%;}

  .equipment-area .equipment-lists{flex-direction:column;}

  .baf-points{font-size:2.727vw;}

  .contact-text{
    width:68.182vw;
    margin-bottom:10.227vw;
    margin-top:4.545vw;
  }

  .btn:before,
  .btn-2:before{
    top:35%;
    left:auto;
    width:3.409vw;
    height:3.409vw;
    right:4.545vw;
  }

  .contact-area .eye{
    width:13.636vw;
    top:-3.409vw;
  }

  .contact-area .btn,
  .btn-2{
    width:80%;
    border-radius:6.818vw;
    border:solid 2px #19488d;
    font-size:3.864vw;
    letter-spacing:1px;
    padding:2.273vw;
  }

  .btn{padding:0;}

  .btn a,
  .btn-2 a{font-size:3.864vw;}

  .fv-bg image{width:100%;}

  .intro-text h4{font-size:2.727vw;}
  .intro-text h3{font-size:3.864vw;}

  .section-title > span:not(.section-title-char){
    font-size:4.773vw;
    margin-top:4.545vw;
  }

  .reason-area .intro-text{width:80%;}

  .reason-area .intro-text::before{
    width:4.545vw;
    left:-6.818vw;
  }

  .reason-area .intro-text::after{
    width:4.545vw;
    right:-6.818vw;
  }

  .section-title{margin-bottom:4.545vw;}

  .reason-list ul:nth-of-type(1) .point-box img:nth-child(1){
    width:45.455vw;
    top:0.682vw;
    left:2.273vw;
    right:0;
    margin:auto;
  }

  .reason-list .point-box{
    width:100%;
    padding:13.636vw 6.818vw 11.364vw;
    margin-top:4.545vw;
    border-radius:4.545vw;
  }

  .reason-list .point-box img{
    width:50%;
    margin:0 auto;
  }

  .reason-list ul .point-box h3{
    font-size:3.864vw;
    color:#19488d;
    margin-bottom:4.545vw;
    text-align:center;
  }

  .point-box p.YuGothic{
    font-weight:normal;
    font-size:2.727vw;
    text-align:center;
  }

  .reason-list{
    column-gap:normal;
    row-gap:11.364vw;
    margin-top:18.182vw;
  }

  .reason-list ul:nth-of-type(2) .point-box img:nth-child(1){
    width:31.818vw;
    top:0;
  }

  .reason-list ul:nth-of-type(3) .point-box img:nth-child(1){
    width:34.091vw;
    top:-2.273vw;
  }

  .reason-list ul:nth-of-type(4) .point-box img:nth-child(1){
    width:28.409vw;
    top:0;
  }

  .reason-list ul:nth-of-type(5) .point-box img:nth-child(1){
    width:27.273vw;
    top:-1.136vw;
  }

  .check-list{
    gap:6.818vw;
    font-size:2.727vw;
    line-height:2;
    padding-bottom:11.364vw;
  }

  .window{
    width:100%;
    padding:18.182vw 0 4.545vw;
  }

  .check-list li::before{
    left:-2.273vw;
    width:2.273vw;
    height:2.273vw;
  }

  .t-reason{
    width:95%;
    padding:4.545vw 0;
    border-bottom:2px solid;
    border-top:2px solid;
  }

  .t-reason h3{font-size:3.864vw;}

  .t-reason p{
    padding-top:4.545vw;
    font-size:2.727vw;
  }

  .baf-list{
    margin-top:11.364vw;
    margin-bottom:11.364vw;
    flex-direction:column;
    gap:6.818vw;
  }

  .baf-card{
    border-radius:4.545vw;
    padding:6.818vw 4.545vw 22.727vw;
  }

  .baf-card .baf-label{
    font-size:5.455vw;
    margin-bottom:4.545vw;
  }

  .baf-points li{
    font-size:2.727vw;
    padding-left:4.545vw;
  }

  .baf-points li + li{margin-top:2.273vw;}

  .baf-points li::before{
    width:2.273vw;
    height:2.273vw;
    top:2.727vw;
  }

  .baf-points li.baf-illast{
    width:63%;
    bottom:-11.364vw;
    margin:0 auto;
  }

  .baf-arrow img{transform:rotate(90deg);}

  .baf-arrow{
    width:6.818vw;
    min-width:6.818vw;
    margin:0 auto;
    padding-top:11.364vw;
  }

  .after-card .baf-points li.baf-illast{
    width:45.455vw;
    left:0;
  }

  .tab-switch{
    width:100%;
    border-radius:4.545vw;
    border:1px solid rgba(0,0,0,0.08);
    box-shadow:1px 2px rgba(0,0,0,0.1);
  }

  .tab-switch label:first-of-type{
    border-top-left-radius:4.545vw;
    border-bottom-left-radius:0;
  }

  .tab-switch label:has(:checked)::before{
    top:calc(100% - 1px);
    left:50%;
    transform:translateX(-50%);
    width:2.273vw;
    height:2.273vw;
    clip-path:polygon(0 0,100% 0,50% 100%);
    z-index:1;
  }

  .tab-switch > label{display:none;}

  .flow-list ul{width:48%;}

.flow-list ul:nth-of-type(4) {
    width: 48%;
}

.flow-list ul:first-of-type .flow-title{
  padding: 2.273vw 2.273vw 2.273vw 4.273vw;
}

  .tab-nav{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0;
    padding:2.727vw 5.455vw;
    margin:0 auto 7.273vw;
    border-radius:4.545vw;
    background-color:#000;
    color:#fff;
  }

  .tab-nav-btn{
    width:6.818vw;
    height:6.818vw;
    border-radius:50%;
    border:none;
    background-color:#fff;
    color:#000;
    display:flex;
    justify-content:center;
    align-items:center;
    font-size:3.182vw;
    font-weight:700;
    flex-shrink:0;
    cursor:pointer;
    transition:transform 0.2s ease,box-shadow 0.2s ease;
    box-shadow:0 6px 20px rgba(0,0,0,0.25);
  }

  .tab-nav-btn[data-dir="prev"]::before{content:"<";}
  .tab-nav-btn[data-dir="next"]::before{content:">";}

  .tab-nav-btn:disabled{
    opacity:0.35;
    cursor:default;
    box-shadow:none;
  }

  .tab-nav-btn:not(:disabled):active{transform:translateY(1px);}

  .tab-nav-viewport{
    flex:1;
    overflow:hidden;
    margin:0 5.455vw;
  }

  .tab-nav-track{
    display:flex;
    gap:10.909vw;
    align-items:center;
    transition:transform 0.3s ease;
  }

  .tab-nav-pill{
    border:none;
    background:transparent;
    color:#fff;
    font-size:3.182vw;
    font-weight:700;
    letter-spacing:0.08em;
    white-space:nowrap;
    cursor:pointer;
    transition:color 0.2s ease;
    min-width:9.091vw;
    text-align:center;
  }

  .tab-nav-pill--active{
    color:#ffd900;
    font-size:3.182vw;
    font-weight:700;
    letter-spacing:1px;
  }

  .tab-nav.sp-only{display:flex!important;}
  .tab-nav{display:flex;}

  .tab-content{padding:0 4.545vw 4.545vw;}
  .tab-content > ul:first-of-type{width:100%;}

  .tab-content h4{font-size:3.182vw;}
  .tab-content p{font-size:2.727vw;}

  .equipment-table{
    margin-top:4.545vw;
    font-size:2.727vw;
  }

  .equipment-table-header span{
    letter-spacing:2px;
    font-size:2.727vw;
    border-bottom:1px solid rgba(0,0,0,0.25);
  }

  .equipment-table-body li span:nth-child(1),
  .equipment-table-body li span:nth-child(2){letter-spacing:1px;}

  .equipment-table-header span,
  .equipment-table-body li span{padding:2.273vw 0;}

  .flow-list{
    width:100%;
    justify-content:space-between;
    gap:2.273vw;
    row-gap:13.636vw;
    padding-top:11.364vw;
    padding-bottom:22.727vw;
  }

  .flow-title{
    font-size:3.182vw;
    padding:2.273vw;
  }

  .flow-list ul:not(:first-of-type) .flow-title{
    padding:2.273vw 2.273vw 2.273vw 4.273vw;
  }

  .flow-text{
    font-size:2.727vw;
    width:95%;
  }

  .flow-title img{
    width:9.091vw;
    left:0;
    top:-6.818vw;
  }

  .faq-area:before{
    width:27.273vw;
    height:27.273vw;
    right:0;
    top:0;
  }

  .faq-area{
    padding:11.364vw 4.545vw;
    width:100%;
    margin-bottom:18.182vw;
    border-radius:6.818vw;
  }

  .faq-question{
    align-items:baseline;
    font-size:3.182vw;
    padding:2.273vw;
    border-radius:4.545vw;
    gap:2.273vw;
    line-height:1.5;
    letter-spacing:1px;
  }

  .faq-toggle::before,
  .faq-toggle::after{
    width:2.273vw;
    height:2px;
  }

  .faq-answer .YuGothic{
    width:100%;
    font-size:2.727vw;
  }

  .faq-answer{
    padding:2.273vw 4.545vw 6.818vw;
    margin-top:0;
  }

  .eye-2{
    width:13.636vw;
    top:-3.409vw;
  }

  .footer .window{
    width:90%;
    margin-bottom:0;
    top:-63.636vw;
  }

  .flow-area{padding-bottom:56.818vw;}

  .footer .t-reason{margin-top:40.909vw;}

  .contact-area .logo{
    width:27.273vw;
    margin:0 auto 0;
  }

  .footer{padding:11.364vw 6.818vw;}
}
