@charset "UTF-8";
/*--------------------------------------*
  * foundation
*--------------------------------------*/
/*--------------------------------------*
    * layout
*--------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");
@media screen and (max-width:767px) {
  .header {
    border-top: 2px solid var(--dark-blue);
  }
}

.header__inner {
  width: min(1200px, 95%);
  margin-inline: auto;
}
@media screen and (max-width:767px) {
  .header__inner {
    width: 100%;
    padding-inline: 2vw;
  }
}

.header__wrap .header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__top {
  background: var(--blue);
  color: white;
  font-size: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
  padding: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem) 0 clamp(0.3529411765rem, 0.7352941176vw, 0.625rem);
}
.header__top h1 {
  font-weight: normal;
}
@media screen and (max-width:767px) {
  .header__top {
    display: none;
  }
}

.header__cta-sp {
  display: none;
}
@media screen and (max-width:767px) {
  .header__cta-sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: fixed;
    bottom: 0;
    height: 17.3333333333vw;
    width: 100%;
    z-index: 11;
    left: 0;
  }
}
.header__cta-sp a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: white;
  font-size: 3.7333333333vw;
  font-weight: bold;
  background-color: var(--orange);
}
@media screen and (max-width:767px) {
  .header__cta-sp a {
    width: 50%;
  }
}
@media screen and (max-width:767px) {
  .header__cta-sp a img {
    width: 6.5vw;
    margin-right: 2vw;
  }
}
@media screen and (max-width:767px) {
  .header__cta-sp a img:nth-child(2) {
    width: 3vw;
  }
}
.header__cta-sp a:first-child {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.header__cta-sp a:nth-child(2) {
  background-color: var(--dark-blue);
}
.header__cta-sp a:nth-child(2) img {
  width: 8.4vw;
}
.header__cta-sp a p {
  font-size: 5.3333333333vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: -1vw;
}
.header__cta-sp a span {
  font-size: 3.2vw;
  font-weight: normal;
  margin-left: 3vw;
  margin-top: 0.4vw;
}

.header__wrap {
  padding: 0.5vw 0;
}
@media screen and (max-width:767px) {
  .header__wrap {
    padding: 2vw 0;
  }
}

.header__logo-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__logo {
  width: clamp(2.2588235294rem, 4.7058823529vw, 4rem);
  margin-right: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
}
@media screen and (max-width:767px) {
  .header__logo {
    width: 8vw;
  }
}

.header__logo-sub {
  width: clamp(9.8823529412rem, 20.5882352941vw, 17.5rem);
}
@media screen and (max-width:767px) {
  .header__logo-sub {
    width: 37.3333333333vw;
  }
}
@media screen and (max-width:767px) {
  .header__logo-sub img {
    height: 100%;
    display: block;
  }
}

.header__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 0.2vw;
}
@media screen and (max-width:767px) {
  .header__nav {
    display: none;
  }
}

.button-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width:767px) {
  .button-wrap {
    position: fixed;
    bottom: 0;
    width: 100%;
    left: 0;
    z-index: 10;
  }
}
@media screen and (max-width:767px) {
  .button-wrap a:nth-child(2) {
    display: none;
  }
}

.header__tel {
  font-size: clamp(1.1294117647rem, 2.3529411765vw, 2rem);
  color: var(--orange);
  margin-right: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
  font-weight: bold;
  line-height: 0.8421052632;
  text-align: left;
}
@media screen and (max-width:767px) {
  .header__tel {
    display: none;
  }
}
.header__tel span {
  color: var(--black);
  font-size: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
  display: block;
  line-height: 0.8571428571;
  margin-top: 5px;
  font-weight: normal;
}

.header__tel-sp {
  display: none;
}
@media screen and (max-width:767px) {
  .header__tel-sp {
    display: block;
  }
}

footer {
  padding-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  padding-bottom: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  footer {
    padding-top: 0;
    padding-bottom: 20vw;
    margin-top: 5.3333333333vw;
    padding-inline: 5.3333333333vw;
  }
}

.footer__nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(0.4588235294rem, 0.9558823529vw, 0.8125rem);
  margin-right: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
}
@media screen and (max-width:767px) {
  .footer__nav ul {
    padding: 0;
    margin-right: 0;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 1.8666666667vw;
  }
}
@media screen and (max-width:767px) {
  .footer__nav ul li {
    margin-right: 0;
    margin-top: 0px;
  }
}
.footer__nav ul li a {
  font-size: clamp(0.4588235294rem, 0.9558823529vw, 0.8125rem);
  color: var(--blue);
  text-decoration: underline;
}
@media screen and (max-width:767px) {
  .footer__nav ul li a {
    font-size: 3.4666666667vw;
    line-height: 1.5;
  }
}

.footer__copy {
  text-align: center;
  margin-top: 26px;
  font-size: 12px;
  color: var(--black);
  font-weight: normal;
}
@media screen and (max-width:767px) {
  .footer__copy {
    font-size: 2.6666666667vw;
    margin-top: 3.2vw;
  }
}

/*--------------------------------------*
    * component
*--------------------------------------*/
.swiper {
  padding: clamp(2.8235294118rem, 5.8823529412vw, 5rem) 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
@media screen and (max-width:767px) {
  .swiper {
    padding: 9.0666666667vw 0 4vw;
  }
}

.swiper.swiper1 {
  width: 100%;
}
@media screen and (max-width:767px) {
  .swiper.swiper1 {
    padding: 0;
  }
}
@media screen and (max-width: 480px) {
  .swiper.swiper1 {
    height: 275px;
  }
}

.swiper-slide {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  height: 100%;
  font-weight: bold;
  text-wrap: nowrap;
}
.swiper-slide p {
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
}
.swiper-slide.blue {
  color: var(--blue);
}

.swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

.swiper2 {
  margin-top: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
}

.slide-box {
  width: 100%;
  padding: 0 40px;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  place-items: center;
  overflow: hidden;
  text-wrap: nowrap;
}

.slide-box.second {
  margin-top: min(clamp(0.9882352941rem, 2.0588235294vw, 1.75rem), 3vw);
}
@media screen and (max-width:767px) {
  .slide-box.second {
    margin-top: 3.2vw;
  }
}

.slide-text {
  display: inline-block;
}
.slide-text span {
  margin-right: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .slide-text span {
    font-size: 3.2vw;
    margin-right: 5.8666666667vw;
  }
}
.slide-text span.blue {
  color: var(--blue);
}

.cta {
  background-image: url("../../assets/img/bg_cta.png");
  background-size: cover;
  background-repeat: no-repeat;
  padding-top: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  padding-bottom: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
}
@media screen and (max-width:767px) {
  .cta {
    display: none;
  }
}

.cta__content h2 {
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  color: white;
  font-weight: bold;
  line-height: 1.35;
  white-space: nowrap;
}
@media screen and (max-width:767px) {
  .cta__content h2 {
    text-align: center;
    font-size: 18px;
  }
}

.cta__card-wrap {
  width: min(980px, 95%);
  margin: clamp(1.7647058824rem, 3.6764705882vw, 3.125rem) auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 40px;
}

.cta__card {
  background-color: white;
  width: 33.3333333333%;
  padding-top: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
  padding-bottom: clamp(0.9176470588rem, 1.9117647059vw, 1.625rem);
  text-align: center;
  border-radius: 8px;
  height: clamp(5.6470588235rem, 11.7647058824vw, 10rem);
}
.cta__card:first-child .cta__card-item {
  margin-top: clamp(0.3529411765rem, 0.7352941176vw, 0.625rem);
}

.cta__card-head {
  position: relative;
}
.cta__card-head p {
  font-size: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  font-weight: bold;
  padding-bottom: clamp(0.7764705882rem, 1.6176470588vw, 1.375rem);
}
.cta__card-head::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  height: 2px;
  width: 60px;
  background-color: var(--orange);
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.cta__card-item {
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
}
.cta__card-item p {
  color: var(--dark-blue);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
  font-weight: bold;
  line-height: 1.1875;
  letter-spacing: 0.04em;
  margin-right: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
}
.cta__card-item p img {
  width: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  margin-right: clamp(0.1411764706rem, 0.2941176471vw, 0.25rem);
  margin-top: clamp(0.1411764706rem, 0.2941176471vw, 0.25rem);
}
.cta__card-item span {
  font-size: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
  display: block;
  margin-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
}

.orange {
  color: var(--orange);
  font-weight: bold;
}

/* ---------------------------------------------------
 * アコーディオン
/* ---------------------------------------------------*/
.accordion {
  width: min(980px, 95%);
  margin-top: clamp(2.6823529412rem, 5.5882352941vw, 4.75rem);
  margin-inline: auto;
}
@media screen and (max-width:767px) {
  .accordion {
    width: 100%;
    margin-top: 10.6666666667vw;
  }
}

.accordion-header {
  position: relative;
  width: 100%;
  color: var(--blue);
  border: none;
  padding: 1rem;
  text-align: left;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: var(--light-blue);
  padding: clamp(0.3882352941rem, 0.8088235294vw, 0.6875rem) clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  font-weight: bold;
  line-height: 1.5;
}
@media screen and (max-width:767px) {
  .accordion-header {
    padding: 3.7333333333vw;
  }
}

.accordion-item {
  border-bottom: 2px solid var(--color-gold);
  margin-top: clamp(0.4941176471rem, 1.0294117647vw, 0.875rem);
  font-size: min(24px, 4vw);
  font-weight: bold;
  color: var(--blue);
  background-color: white;
}
@media screen and (max-width:767px) {
  .accordion-item {
    margin-top: rclamp-sm(10);
  }
}
.accordion-item:first-child {
  border-top: 2px solid var(--color-gold);
}

.accordion-content {
  position: relative;
  max-height: 0;
  overflow: hidden;
  border-radius: 0 0 10px 10px;
  -webkit-transition: max-height 0.5s ease;
  transition: max-height 0.5s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: var(--light-blue);
}
@media screen and (max-width:767px) {
  .accordion-content p {
    font-size: 3.7333333333vw;
    line-height: 1.5;
  }
}
.accordion-content::after {
  position: absolute;
  top: 0%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  content: "";
  width: 100%;
  max-width: 95%;
  height: 1px;
  background-color: var(--dark-blue);
}
@media screen and (max-width:767px) {
  .accordion-content::after {
    width: 90%;
    height: 1px;
  }
}

.accordion-inner {
  padding: clamp(0.5647058824rem, 1.1764705882vw, 1rem) clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(0.4941176471rem, 1.0294117647vw, 0.875rem);
  width: 100%;
}
@media screen and (max-width:767px) {
  .accordion-inner {
    padding: 3.7333333333vw;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.accordion-inner p {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  width: 90%;
  line-height: 1.7777777778;
}
@media screen and (max-width:767px) {
  .accordion-inner p {
    font-size: 3.7333333333vw;
    line-height: 1.7142857143;
  }
}
.accordion-inner img {
  width: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  margin-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
  height: auto;
}
@media screen and (max-width:767px) {
  .accordion-inner img {
    width: 8vw;
    margin-top: 1.6vw;
  }
}

.accordion-content.open {
  position: relative;
  max-height: 200px;
  border-radius: 0;
  background: var(--light-blue);
}
.accordion-content.open p {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  width: 90%;
  line-height: 1.7777777778;
}
@media screen and (max-width:767px) {
  .accordion-content.open p {
    font-size: 3.7333333333vw;
    line-height: 1.7142857143;
  }
}

.accordion .title {
  width: 90%;
  text-align: left;
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width:767px) {
  .accordion .title {
    font-size: 4.2666666667vw;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.accordion .title img {
  width: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  margin-right: clamp(0.4941176471rem, 1.0294117647vw, 0.875rem);
  margin-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
}
@media screen and (max-width:767px) {
  .accordion .title img {
    width: 8vw;
    margin-top: 1.6vw;
  }
}

.icon {
  font-weight: lighter;
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
@media screen and (max-width:767px) {
  .icon {
    font-size: 5.8666666667vw;
  }
}

/*--------------------------------------*
    * project
*--------------------------------------*/
:root {
  --orange: #D45C08;
  --dark-blue: #012057;
  --light-blue: #E7F5FF;
  --black: #333333;
  --gold: #B88E39;
  --blue: #16547D;
}

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: var(--black);
  position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin: 0;
  font-size: inherit;
}

a {
  text-decoration: none;
  -webkit-transition: all 0.1s 0s ease;
  transition: all 0.1s 0s ease;
}
a:hover {
  opacity: 0.7;
}
@media screen and (max-width:767px) {
  a:hover {
    opacity: 1;
  }
}

ul {
  margin: 0;
}

li {
  list-style: none;
  margin: 0;
}

img {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 0.75rem;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
}
.wrapper {
  overflow-x: hidden;
}

.section__inner {
  width: 100%;
  max-width: 1360px;
  padding-inline: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
  margin: 0 auto;
}
@media screen and (max-width:767px) {
  .section__inner {
    padding-inline: 5.3333333333vw;
  }
}

/* ---------------------------------------------------
 * button
/* ---------------------------------------------------*/
.button {
  position: relative;
  border-radius: 60px;
  border: 3px solid white;
  color: white;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}
.source {
  background-color: var(--dark-blue);
}

.contact {
  background-color: var(--orange);
}

header .button {
  font-size: clamp(0.5294117647rem, 1.1029411765vw, 0.9375rem);
}
header .source,
header .contact {
  width: clamp(5.7882352941rem, 12.0588235294vw, 10.25rem);
  height: clamp(2.2588235294rem, 4.7058823529vw, 4rem);
}
header .source::after,
header .contact::after {
  content: "";
  background-size: cover;
  position: absolute;
  height: clamp(1.5529411765rem, 3.2352941176vw, 2.75rem);
  width: clamp(3.3176470588rem, 6.9117647059vw, 5.875rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  top: 8%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width:767px) {
  header .source::after,
  header .contact::after {
    display: none;
  }
}
header .source {
  margin-right: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
}
@media screen and (max-width:767px) {
  header .source {
    margin-right: 0;
  }
}
header .source img {
  width: clamp(1.1470588235rem, 2.3897058824vw, 2.03125rem);
  margin-right: clamp(0.1270588235rem, 0.2647058824vw, 0.225rem);
}
header .source::after {
  background: url("../../assets/img/button_source-deco.png") no-repeat center center;
  background-size: cover;
}
@media screen and (max-width:767px) {
  header .source::after {
    display: none;
  }
}
header .contact img {
  width: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
  margin-right: clamp(0.2470588235rem, 0.5147058824vw, 0.4375rem);
}
header .contact::after {
  background: url("../../assets/img/button_contact-deco.png") no-repeat center center;
  background-size: cover;
}

.mv__button-wrap .button {
  padding-top: 5px;
  width: clamp(11.2941176471rem, 23.5294117647vw, 20rem);
  height: clamp(2.7529411765rem, 5.7352941176vw, 4.875rem);
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
}
@media screen and (max-width:767px) {
  .mv__button-wrap .button {
    width: 42.6666666667vw;
    max-width: 200px;
    height: 10.6666666667vw;
  }
}
.mv__button-wrap .source::after,
.mv__button-wrap .contact::after {
  content: "";
  background-size: cover;
  position: absolute;
  height: clamp(1.4470588235rem, 3.0147058824vw, 2.5625rem);
  width: clamp(8.0470588235rem, 16.7647058824vw, 14.25rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  top: 8%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.mv__button-wrap .source {
  margin-right: clamp(1.1294117647rem, 2.3529411765vw, 2rem);
}
.mv__button-wrap .source img {
  width: clamp(1.4823529412rem, 3.0882352941vw, 2.625rem);
  margin-right: clamp(0.1058823529rem, 0.2205882353vw, 0.1875rem);
}
.mv__button-wrap .source::after {
  background: url("../../assets/img/button_mv-source-deco.png") no-repeat center center;
  background-size: cover;
}
.mv__button-wrap .contact img {
  width: clamp(1.2705882353rem, 2.6470588235vw, 2.25rem);
  margin-right: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
}
.mv__button-wrap .contact::after {
  background: url("../../assets/img/button_mv-contact-deco.png") no-repeat center center;
  background-size: cover;
}

.cta .button {
  width: clamp(7.2rem, 15vw, 12.75rem);
  height: clamp(1.6941176471rem, 3.5294117647vw, 3rem);
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  margin: 0 auto;
}
.cta .source img {
  width: clamp(1.1647058824rem, 2.4264705882vw, 2.0625rem);
  margin-right: clamp(0.1164705882rem, 0.2426470588vw, 0.20625rem);
}
.cta .contact {
  background-color: var(--orange);
}
.cta .contact img {
  width: clamp(1.2705882353rem, 2.6470588235vw, 2.25rem);
  margin-right: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
}

.button.source.sp {
  display: none;
}
@media screen and (max-width:767px) {
  .button.source.sp {
    display: block;
  }
}

.mv {
  padding-top: clamp(2.1176470588rem, 4.4117647059vw, 3.75rem);
  padding-bottom: clamp(2.3294117647rem, 4.8529411765vw, 4.125rem);
  position: relative;
}
@media screen and (max-width:767px) {
  .mv {
    height: auto;
    padding-top: 3.7333333333vw;
    padding-bottom: 8vw;
    overflow: hidden;
  }
}

.mv__bg {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
}
.mv__bg img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100vw;
}

@media screen and (max-width:767px) {
  .mv .section__inner {
    padding-inline: min(12px, 3vw);
  }
}

.mv__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.mv__sub-title {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  font-weight: bold;
  color: var(--orange);
  border-bottom: 4px solid var(--orange);
  display: inline-block;
  line-height: 0.8275862069;
  padding-bottom: 12px;
}
@media screen and (max-width:767px) {
  .mv__sub-title {
    font-size: 2.9333333333vw;
    border-bottom: 1.5px solid var(--orange);
    padding-bottom: 1vw;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    letter-spacing: 0.05em;
  }
}

.mv__title {
  font-size: clamp(1.6941176471rem, 3.5294117647vw, 3rem);
  line-height: 1.25;
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
}
@media screen and (max-width:767px) {
  .mv__title {
    font-size: 5.0666666667vw;
    margin-top: 2vw;
  }
}
.mv__title span {
  color: var(--blue);
}

.mv__content {
  width: clamp(24rem, 50vw, 42.5rem);
  z-index: 1;
}
@media screen and (max-width:767px) {
  .mv__content {
    width: 100vw;
    margin-top: 0px;
  }
}

.mv__text-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.mv__text {
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  background: -webkit-gradient(linear, left top, right top, from(#ebfeff), to(#D1EBFF));
  background: linear-gradient(to right, #ebfeff, #D1EBFF);
  font-size: clamp(1.0941176471rem, 2.2794117647vw, 1.9375rem);
  color: var(--blue);
  font-weight: bold;
  padding: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem) 0;
  width: 100%;
}
@media screen and (max-width:767px) {
  .mv__text {
    margin-top: 3vw;
    padding: 1.6vw 0;
    width: 70%;
    font-size: 2.6666666667vw;
  }
}
.mv__text span img {
  width: 45px;
}
@media screen and (max-width:767px) {
  .mv__text span img {
    width: 4.8vw;
  }
}

.mv__text-img {
  width: 100%;
  max-width: clamp(16.8rem, 35vw, 29.75rem);
  margin-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
}
@media screen and (max-width:767px) {
  .mv__text-img {
    width: 100%;
    margin-top: 2.1333333333vw;
    max-width: 51.7333333333vw;
  }
}

.mv__lead-img {
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: 1;
  max-width: 686px;
}
@media screen and (max-width:767px) {
  .mv__lead-img {
    bottom: -2%;
    left: 53%;
    width: 55.4666666667vw;
  }
}

.mv__button-wrap {
  position: absolute;
  bottom: auto;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 10;
}

/* ---------------------------------------------------
 * solution
/* ---------------------------------------------------*/
.solution__head {
  position: relative;
  text-align: center;
  padding-top: clamp(1.9764705882rem, 4.1176470588vw, 3.5rem);
  padding-bottom: clamp(2.5411764706rem, 5.2941176471vw, 4.5rem);
  background: -webkit-gradient(linear, left top, left bottom, from(#F5FBFF), to(#F2FAFF));
  background: linear-gradient(to bottom, #F5FBFF, #F2FAFF);
}
@media screen and (max-width:767px) {
  .solution__head {
    padding-top: 8.5333333333vw;
    padding-bottom: 10.6666666667vw;
  }
}

.solution__deco {
  position: absolute;
  bottom: -6%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100px;
  height: 50px;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: clamp(1.7647058824rem, 3.6764705882vw, 3.125rem) solid transparent;
  border-left: clamp(1.7647058824rem, 3.6764705882vw, 3.125rem) solid transparent;
  border-top: clamp(1.7647058824rem, 3.6764705882vw, 3.125rem) solid #F2FAFF;
  border-bottom: 0;
}
@media screen and (max-width:767px) {
  .solution__deco {
    bottom: -1.3%;
  }
}

.solution__title {
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  font-weight: bold;
}
.solution__title span {
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  line-height: 1.2;
}
@media screen and (max-width:767px) {
  .solution__title span {
    font-size: 4.2666666667vw;
  }
}
.solution__title h2 {
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.08em;
  line-height: 1.2;
  margin-top: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
}
@media screen and (max-width:767px) {
  .solution__title h2 {
    font-size: 6.4vw;
  }
}
.solution__title h2 span {
  font-size: min(2.5rem, 4vw);
}
@media screen and (max-width:767px) {
  .solution__title h2 span {
    font-size: 6.4vw;
  }
}
.solution__title .blue {
  color: var(--blue);
}

.solution__head-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  margin-top: clamp(2.1176470588rem, 4.4117647059vw, 3.75rem);
  width: 100%;
  padding-inline: clamp(3.8823529412rem, 8.0882352941vw, 6.875rem);
}
@media screen and (max-width:767px) {
  .solution__head-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 5.3333333333vw;
    margin-top: 5.3333333333vw;
    padding-inline: 0;
  }
}

.solution__card {
  width: 100%;
  height: auto;
  background-color: #fff;
  padding-top: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
  padding-bottom: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  padding-inline: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
  text-align: left;
  border-radius: 8px;
}
@media screen and (max-width:767px) {
  .solution__card {
    width: 100%;
    max-width: 100%;
    height: auto;
    padding-inline: 5.3333333333vw;
    padding-top: 5.3333333333vw;
    padding-bottom: 5.3333333333vw;
  }
}

.solution__card-img img {
  border-radius: 3px;
}

.solution__card-text {
  color: var(--blue);
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  font-weight: bold;
  margin-top: 14px;
  padding: 0 16px;
  line-height: 1.4444444444;
  text-align: center;
}
@media screen and (max-width:767px) {
  .solution__card-text {
    font-size: 4.2666666667vw;
  }
}

.solution__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  padding-left: 5.8vw;
  width: 110%;
  padding-bottom: 3.2vw;
  padding-top: clamp(0.3529411765rem, 0.7352941176vw, 0.625rem);
}
@media screen and (max-width:767px) {
  .solution__content {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-left: 0;
    padding-bottom: 10.1333333333vw;
  }
}

.solutin__text-wrap {
  position: relative;
  width: 70%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width:767px) {
  .solutin__text-wrap {
    width: 100%;
    margin-top: 10.1333333333vw;
  }
}
.solutin__text-wrap p {
  font-size: clamp(2.4705882353rem, 5.1470588235vw, 4.375rem);
  color: var(--dark-blue);
  font-weight: bold;
  line-height: 1.3714285714;
}
@media screen and (max-width:767px) {
  .solutin__text-wrap p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 5.3333333333vw;
  }
}
.solutin__text-wrap p img {
  display: none;
}
@media screen and (max-width:767px) {
  .solutin__text-wrap p img {
    display: block;
    width: 30%;
    height: 100%;
  }
}
.solutin__text-wrap span {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  line-height: 1.7777777778;
  color: var(--black);
  font-weight: bold;
  padding: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  display: block;
}
@media screen and (max-width:767px) {
  .solutin__text-wrap span {
    padding: 4vw;
    font-size: 3.2vw;
  }
}

.solutin__img-wrap {
  width: 36%;
  margin-left: -13%;
}
@media screen and (max-width:767px) {
  .solutin__img-wrap {
    width: 70%;
    display: none;
  }
}
.solutin__img-wrap img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.solution_sub-text {
  position: relative;
  width: 82%;
  margin-top: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
}
@media screen and (max-width:767px) {
  .solution_sub-text {
    width: 100%;
    margin-top: 4.2666666667vw;
  }
}

.solution_sub-text-deco01 {
  position: absolute;
  top: 0px;
  left: 0%;
  width: 100px;
  height: 60px;
  background-color: white;
  border-top: 1px solid var(--gold);
  border-left: 1px solid var(--gold);
  z-index: -1;
}
@media screen and (max-width:767px) {
  .solution_sub-text-deco01 {
    width: 26.6666666667vw;
    height: 16vw;
  }
}

.solution_sub-text-deco02 {
  position: absolute;
  bottom: 0px;
  right: 0%;
  width: 100px;
  height: 60px;
  background-color: white;
  border-bottom: 1px solid var(--gold);
  border-right: 1px solid var(--gold);
  z-index: -1;
}
@media screen and (max-width:767px) {
  .solution_sub-text-deco02 {
    width: 26.6666666667vw;
    height: 16vw;
  }
}

/* ---------------------------------------------------
 * feature
/* ---------------------------------------------------*/
.feature {
  padding-bottom: 70px;
}
@media screen and (max-width:767px) {
  .feature {
    padding-bottom: 10.6666666667vw;
  }
}
.feature .font_roboto {
  font-family: "Roboto", sans-serif;
  font-style: italic;
  padding-bottom: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}

.feature__title {
  position: relative;
  background-color: var(--light-blue);
  text-align: center;
  border-bottom: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem) solid #9EBAD2;
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
  padding-inline: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
  padding-top: clamp(1.8352941176rem, 3.8235294118vw, 3.25rem);
  padding-bottom: clamp(1.9058823529rem, 3.9705882353vw, 3.375rem);
}
.feature__title::after {
  content: "";
  position: absolute;
  bottom: 0%;
  left: 71%;
  height: clamp(7.1647058824rem, 14.9264705882vw, 12.6875rem);
  width: clamp(13.4823529412rem, 28.0882352941vw, 23.875rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-image: url("../../assets/img/feature_title-deco.png");
  background-size: cover;
  z-index: 1;
}
@media screen and (max-width:767px) {
  .feature__title::after {
    background-size: contain;
    background-repeat: no-repeat;
    right: -10%;
    bottom: 0%;
    height: 16vw;
    width: 32vw;
    aspect-ratio: 382/204;
  }
}
@media screen and (max-width:767px) {
  .feature__title {
    border-bottom: 2.6666666667vw solid #9EBAD2;
    padding-top: 6.4vw;
    padding-bottom: 6.4vw;
    padding-inline: 12vw;
  }
}
.feature__title h2 {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  color: var(--blue);
  font-weight: normal;
  z-index: 2;
  margin-top: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  .feature__title h2 {
    font-size: 4vw;
    display: block;
  }
}
.feature__title h2 img {
  width: clamp(16.0941176471rem, 33.5294117647vw, 28.5rem);
  margin-right: clamp(0.3529411765rem, 0.7352941176vw, 0.625rem);
}
@media screen and (max-width:767px) {
  .feature__title h2 img {
    width: 60%;
  }
}
.feature__title h2 span {
  font-size: clamp(3.8823529412rem, 8.0882352941vw, 6.875rem);
}
@media screen and (max-width:767px) {
  .feature__title h2 span {
    font-size: 8.5333333333vw;
  }
}

.feature__content {
  margin-top: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
}
@media screen and (max-width:767px) {
  .feature__content {
    margin-top: 12.2666666667vw;
  }
}

.feature__box {
  margin-top: clamp(2.8941176471rem, 6.0294117647vw, 5.125rem);
  position: absolute;
  position: relative;
}
.feature__box:first-child {
  margin-top: 0;
}
@media screen and (max-width:767px) {
  .feature__box {
    margin-top: 9.6vw;
  }
}

.spin_box {
  position: absolute;
  left: -21%;
  z-index: 10;
  top: -3%;
  width: clamp(14.8235294118rem, 30.8823529412vw, 26.25rem);
}
@media screen and (max-width:767px) {
  .spin_box {
    display: none;
  }
}

.spin_box.two {
  left: unset;
  right: -21%;
}

.spin-img {
  -webkit-animation: spin 20s linear infinite;
          animation: spin 20s linear infinite;
  display: inline-bock;
  width: 100%;
}

.spin-num {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  font-size: min(70px, 4vw);
  color: var(--dark-blue);
  font-weight: bold;
  text-align: center;
  z-index: 20;
  width: clamp(4.1647058824rem, 8.6764705882vw, 7.375rem);
}

@-webkit-keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes spin {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.feature__box-head {
  text-align: center;
}
.feature__box-head h3 {
  font-size: clamp(2.4705882353rem, 5.1470588235vw, 4.375rem);
  color: var(--dark-blue);
}
@media screen and (max-width:767px) {
  .feature__box-head h3 {
    font-size: 6.4vw;
  }
}
.feature__box-head img {
  width: clamp(3.6rem, 7.5vw, 6.375rem);
  margin-bottom: clamp(0.9176470588rem, 1.9117647059vw, 1.625rem);
}
@media screen and (max-width:767px) {
  .feature__box-head img {
    width: 16vw;
    margin-bottom: 6.4vw;
  }
}

.feature__item {
  width: 100%;
  margin-inline: auto;
  background-color: var(--light-blue);
  padding-bottom: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
  margin-top: clamp(1.9058823529rem, 3.9705882353vw, 3.375rem);
}
@media screen and (max-width:767px) {
  .feature__item {
    margin-top: 8vw;
    padding-bottom: 5.3333333333vw;
  }
}

.feature__item.third {
  padding-bottom: clamp(2.5411764706rem, 5.2941176471vw, 4.5rem);
}
@media screen and (max-width:767px) {
  .feature__item.third {
    padding-bottom: 10.6666666667vw;
  }
}

.feature__item-inner {
  width: 100%;
  margin: 0 auto;
  padding-inline: clamp(3.8823529412rem, 8.0882352941vw, 6.875rem);
}
@media screen and (max-width:767px) {
  .feature__item-inner {
    width: 100%;
    padding-inline: 5.3333333333vw;
  }
}

.feature__item-head {
  position: relative;
  background-color: var(--blue);
  color: white;
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  text-align: center;
  padding-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  padding-bottom: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  z-index: 2;
}
@media screen and (max-width:767px) {
  .feature__item-head {
    font-size: 4.8vw;
    padding-top: 3.2vw;
    padding-bottom: 3.2vw;
  }
}
.feature__item-head p {
  position: relative;
  z-index: 2;
}
.feature__item-head img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 106px;
  height: 100%;
  z-index: 1;
}
@media screen and (max-width:767px) {
  .feature__item-head img {
    width: 17.6vw;
  }
}

.feature__item-head.third img {
  width: 164px;
}
@media screen and (max-width:767px) {
  .feature__item-head.third img {
    width: 26.6666666667vw;
  }
}

.feature__item-text {
  color: var(--blue);
  line-height: 1.5;
  margin-top: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .feature__item-text {
    margin-top: 4.2666666667vw;
  }
}
.feature__item-text p {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  .feature__item-text p {
    font-size: 4.8vw;
  }
}
.feature__item-text span {
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  font-size: clamp(0.7764705882rem, 1.6176470588vw, 1.375rem);
  color: var(--black);
  line-height: 1.5;
  display: block;
  font-weight: normal;
}
@media screen and (max-width:767px) {
  .feature__item-text span {
    font-size: 4.2666666667vw;
  }
}

.feature__item-img {
  width: 100%;
  padding-inline: clamp(2.1882352941rem, 4.5588235294vw, 3.875rem);
  background-color: white;
  margin-top: clamp(1.5529411765rem, 3.2352941176vw, 2.75rem);
  margin-inline: auto;
  padding-top: clamp(1.1294117647rem, 2.3529411765vw, 2rem);
  padding-bottom: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
}
.feature__item-img span {
  font-size: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  line-height: 1.5;
  text-align: center;
  display: block;
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
}
@media screen and (max-width:767px) {
  .feature__item-img span {
    text-align: left;
  }
}
@media screen and (max-width:767px) {
  .feature__item-img {
    padding: 5.3333333333vw 3.2vw 3.2vw;
    margin-top: 5.3333333333vw;
  }
}

.feature__item-img.second {
  padding: 60px 62px 54px;
}
@media screen and (max-width:767px) {
  .feature__item-img.second {
    padding: 5.3333333333vw;
  }
}

.feature__item-img.third {
  padding: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
}
@media screen and (max-width:767px) {
  .feature__item-img.third {
    padding: 5.3333333333vw;
  }
}

.feature__item-img.third-bottom {
  padding: 8px 62px 54px;
  padding: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem) clamp(2.1882352941rem, 4.5588235294vw, 3.875rem) clamp(1.6941176471rem, 3.5294117647vw, 3rem);
}
@media screen and (max-width:767px) {
  .feature__item-img.third-bottom {
    padding: 5.3333333333vw;
  }
}

.feature__item-caution {
  font-size: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
  text-align: right;
  padding-right: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
  margin-top: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
}
@media screen and (max-width:767px) {
  .feature__item-caution {
    margin-top: 2.1333333333vw;
    font-size: 1.8666666667vw;
  }
}

.feature__item-bottom {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  line-height: 1.7777777778;
  text-align: center;
  color: var(--blue);
  font-weight: bold;
  margin-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
}

.feature__plus-icon {
  width: clamp(2.1176470588rem, 4.4117647059vw, 3.75rem);
  margin: clamp(1.2705882353rem, 2.6470588235vw, 2.25rem) auto 0;
  display: block;
}
@media screen and (max-width:767px) {
  .feature__plus-icon {
    margin: 5.3333333333vw auto 0;
    width: 9.0666666667vw;
  }
}

.feature__item-img-head {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  font-weight: bold;
  color: var(--blue);
  text-align: center;
  line-height: 1.5;
}

.feature__item-bottom-img {
  width: 100%;
  max-width: 412px;
  margin: 0 auto;
  display: block;
  margin-top: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
}

.feature__bottom {
  margin-top: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
}
@media screen and (max-width:767px) {
  .feature__bottom {
    margin-top: 12vw;
  }
}
.feature__bottom p {
  font-size: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  text-align: center;
  color: var(--dark-blue);
  font-weight: bold;
  position: relative;
  padding-bottom: clamp(1.2rem, 2.5vw, 2.125rem);
}
@media screen and (max-width:767px) {
  .feature__bottom p {
    font-size: 5.8666666667vw;
    padding-bottom: 5.3333333333vw;
  }
}
.feature__bottom p::after {
  content: "";
  position: absolute;
  bottom: 0%;
  left: 50%;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
  height: 2px;
  width: 60px;
  background-color: var(--orange);
}
@media screen and (max-width:767px) {
  .feature__bottom p::after {
    width: 16vw;
  }
}
.feature__bottom p:nth-child(2) {
  font-size: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  line-height: 1.7777777778;
  text-align: center;
  color: var(--black);
  display: block;
  margin-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
  font-weight: bold;
  padding-bottom: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
}
@media screen and (max-width:767px) {
  .feature__bottom p:nth-child(2) {
    font-size: 2.9333333333vw;
    margin-top: 3.2vw;
    padding-bottom: 4.2666666667vw;
  }
}
.feature__bottom p:nth-child(2)::after {
  display: none;
}

.feature__bottom-lead {
  font-size: min(30px, 4vw);
  line-height: 1.2;
  font-weight: bold;
  display: block;
  text-align: center;
  color: var(--dark-blue);
}
@media screen and (max-width:767px) {
  .feature__bottom-lead {
    font-size: 4vw;
  }
}

.feature__bottom-head {
  text-align: center;
}

.feature__bottom-img {
  width: min(980px, 95%);
  margin: clamp(2.1176470588rem, 4.4117647059vw, 3.75rem) auto 0;
}
@media screen and (max-width:767px) {
  .feature__bottom-img {
    margin: 9.0666666667vw auto 0;
    max-width: 86.6666666667vw;
  }
}

.underline {
  position: relative;
  display: inline-block;
  --underline-width: 0%;
  /* 初期状態 */
}

.underline::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 14px;
  background-color: var(--orange);
  width: var(--underline-width);
  z-index: -1;
}
@media screen and (max-width:767px) {
  .underline::after {
    bottom: -4%;
    height: 5px;
  }
}

.feature__bottom-lead.underline {
  text-align: center;
}
.feature__bottom-lead.underline::after {
  height: 6px;
}
@media screen and (max-width:767px) {
  .feature__bottom-lead.underline::after {
    height: 1.6vw;
  }
}

.feature__bottom-caution {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: clamp(0.7058823529rem, 1.4705882353vw, 1.25rem);
}
@media screen and (max-width:767px) {
  .feature__bottom-caution {
    margin-top: 2.6666666667vw;
    grid-template-columns: 1fr;
  }
}
.feature__bottom-caution ul {
  width: 100%;
  padding: 0;
}
@media screen and (max-width:767px) {
  .feature__bottom-caution ul {
    width: 100%;
  }
}
@media screen and (max-width:767px) {
  .feature__bottom-caution ul:nth-child(2) {
    width: 100%;
  }
}
.feature__bottom-caution ul li {
  font-size: max(8px, clamp(0.4235294118rem, 0.8823529412vw, 0.75rem));
  margin-top: clamp(0.1764705882rem, 0.3676470588vw, 0.3125rem);
  line-height: 1.3;
  width: 100%;
  text-wrap: nowrap;
}
@media screen and (max-width:767px) {
  .feature__bottom-caution ul li {
    font-size: 2.6666666667vw;
    margin-top: 1.0666666667vw;
    text-wrap: wrap;
  }
}

/* ---------------------------------------------------
 * example
/* ---------------------------------------------------*/
.example__title {
  background-image: url("../../assets/img/bg_example-head.png");
  background-size: cover;
  background-repeat: no-repeat;
  padding: clamp(7.7647058824rem, 16.1764705882vw, 13.75rem) 0;
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
}
@media screen and (max-width:767px) {
  .example__title {
    padding: 13.3333333333vw;
  }
}
.example__title h2 {
  font-size: clamp(2.4705882353rem, 5.1470588235vw, 4.375rem);
  color: var(--dark-blue);
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .example__title h2 {
    font-size: 8vw;
  }
}

.example__wrap {
  margin-top: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
  padding-bottom: clamp(2.8941176471rem, 6.0294117647vw, 5.125rem);
}
@media screen and (max-width:767px) {
  .example__wrap {
    margin-top: 12vw;
    padding-bottom: 16vw;
  }
}

.example__box {
  position: relative;
}
.example__box:nth-child(2) {
  margin-top: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
}
@media screen and (max-width:767px) {
  .example__box:nth-child(2) {
    margin-top: 21.3333333333vw;
  }
}

.example__wrap-inner {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
}

.example__box-head {
  border: 2px solid var(--blue);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
  width: 100%;
}
@media screen and (max-width:767px) {
  .example__box-head {
    height: auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.example__box-head h3 {
  width: 20%;
  max-width: 158px;
  font-size: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  color: var(--blue);
  font-weight: bold;
  margin-bottom: 16px;
  background-color: var(--blue);
  color: white;
  margin: 0;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
  font-weight: normal;
}
@media screen and (max-width:767px) {
  .example__box-head h3 {
    font-size: 6.4vw;
    width: 100%;
    max-width: 100%;
    padding: 2.1333333333vw;
  }
}

.example__head-right {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-inline: clamp(1.1294117647rem, 2.3529411765vw, 2rem) clamp(0.3529411765rem, 0.7352941176vw, 0.625rem);
}
@media screen and (max-width:767px) {
  .example__head-right {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 5.3333333333vw;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.example__head-right p {
  color: var(--blue);
  font-size: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .example__head-right p {
    font-size: 6.4vw;
  }
}
.example__head-right p span {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  .example__head-right p span {
    font-size: 4.8vw;
  }
}
@media screen and (max-width:767px) {
  .example__head-right p span .sp-24 {
    font-size: 6.4vw;
  }
}
.example__head-right ul {
  padding: 0;
}
@media screen and (max-width:767px) {
  .example__head-right ul {
    padding-left: 4.8vw;
    margin-top: 4.8vw;
    font-size: 4.2666666667vw;
  }
}
.example__head-right ul li {
  list-style: disc;
}
.example__head-right ul li:nth-child(2) {
  margin-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
}

.example__content {
  margin-top: clamp(1.9764705882rem, 4.1176470588vw, 3.5rem);
}
@media screen and (max-width:767px) {
  .example__content {
    margin-top: 8vw;
  }
}

.example__content-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 24px;
}

.example__content-left {
  max-width: 158px;
}
@media screen and (max-width:767px) {
  .example__content-left {
    display: none;
  }
}

.example__content-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width:767px) {
  .example__content-right {
    width: 100%;
  }
}

.example__right-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  position: relative;
}
@media screen and (max-width:767px) {
  .example__right-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8.5333333333vw;
  }
}

.example__content-bottom {
  width: 100%;
  height: clamp(7.7647058824rem, 16.1764705882vw, 13.75rem);
  margin-top: clamp(-7.125rem, -8.3823529412vw, -2.85rem);
  padding-top: clamp(4.0235294118rem, 8.3823529412vw, 7.125rem);
  padding-bottom: clamp(1.2rem, 2.5vw, 2.125rem);
  background: #E7EDF2;
  z-index: -1;
  padding-left: clamp(1.2705882353rem, 2.6470588235vw, 2.25rem);
  aspect-ratio: 798/220;
}
@media screen and (max-width:767px) {
  .example__content-bottom {
    height: auto;
    margin-top: -21vw;
    margin-inline: calc(50% - 50vw);
    width: 100vw;
    padding-left: 0;
    padding-top: 29.3333333333vw;
    padding-inline: 5.3333333333vw;
    aspect-ratio: 375/255;
  }
}
.example__content-bottom span {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  color: var(--black);
  font-weight: bold;
  line-height: 1.7777777778;
  text-align: center;
  display: block;
}
@media screen and (max-width:767px) {
  .example__content-bottom span {
    font-size: 4.2666666667vw;
  }
}
.example__content-bottom span .orange {
  color: var(--orange);
  display: inline;
}
.example__content-bottom p {
  font-size: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  margin-top: clamp(0.2823529412rem, 0.5882352941vw, 0.5rem);
  color: var(--orange);
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}
@media screen and (max-width:767px) {
  .example__content-bottom p {
    font-size: 8vw;
  }
}

.example__box.second .exmaple__content-bottom {
  margin-top: -6vw;
}
@media screen and (max-width:767px) {
  .example__box.second .exmaple__content-bottom {
    margin-top: -30vw;
  }
}

.example__cost-wrap {
  margin-top: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  width: 100%;
  margin-top: -10px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .example__cost-wrap {
    width: 100vw;
  }
}

.example__cost-content {
  padding-top: clamp(1.0588235294rem, 2.2058823529vw, 1.875rem);
  padding-bottom: clamp(1.4117647059rem, 2.9411764706vw, 2.5rem);
  background-color: #e7edf2;
}
@media screen and (max-width:767px) {
  .example__cost-content {
    margin-top: 6.4vw;
    padding-top: 8vw;
    padding-bottom: 10.6666666667vw;
  }
}

.example__cost-inner {
  width: 100%;
  padding-inline: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  .example__cost-inner {
    padding-inline: 5.3333333333vw;
  }
}

.example__cost-item.second .example__cost-sub-head {
  margin-top: clamp(1.1294117647rem, 2.3529411765vw, 2rem);
}
@media screen and (max-width:767px) {
  .example__cost-item.second .example__cost-sub-head {
    margin-top: 10.6666666667vw;
  }
}

.example__cost-head {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  color: var(--dark-blue);
}
@media screen and (max-width:767px) {
  .example__cost-head {
    font-size: 6.4vw;
  }
}

.example__cost-sub-head {
  font-size: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  background-color: var(--dark-blue);
  color: white;
  margin-top: clamp(0.6352941176rem, 1.3235294118vw, 1.125rem);
  padding-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
  padding-bottom: clamp(0.1411764706rem, 0.2941176471vw, 0.25rem);
}
@media screen and (max-width:767px) {
  .example__cost-sub-head {
    font-size: 4.8vw;
    margin-top: 4.8vw;
    padding-top: 1.6vw;
    padding-bottom: 1.6vw;
  }
}

.example__cost-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
  margin-top: clamp(0.4941176471rem, 1.0294117647vw, 0.875rem);
}
@media screen and (max-width:767px) {
  .example__cost-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 4.2666666667vw;
    gap: 8px;
    padding-inline: 6.6666666667vw;
  }
}
.example__cost-flex picture {
  max-width: clamp(7.9058823529rem, 16.4705882353vw, 14rem);
}
@media screen and (max-width:767px) {
  .example__cost-flex picture {
    max-width: 100%;
  }
}

.example__cost-item.second .example__cost-flex {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.cost-plus-icon {
  max-width: clamp(1.1294117647rem, 2.3529411765vw, 2rem);
}
@media screen and (max-width:767px) {
  .cost-plus-icon {
    max-width: 8.5333333333vw;
  }
}

.example__cost-caution {
  text-align: left;
  margin-top: clamp(0.4235294118rem, 0.8823529412vw, 0.75rem);
}
@media screen and (max-width:767px) {
  .example__cost-caution {
    padding-inline: 5.3333333333vw;
    margin-top: 3.2vw;
  }
}
.example__cost-caution p {
  font-size: clamp(0.5647058824rem, 1.1764705882vw, 1rem);
  color: var(--black);
  line-height: 1.5;
  margin-top: clamp(0.2117647059rem, 0.4411764706vw, 0.375rem);
}
@media screen and (max-width:767px) {
  .example__cost-caution p {
    font-size: 4.2666666667vw;
  }
}

/* ---------------------------------------------------
 * flow
/* ---------------------------------------------------*/
.flow {
  background-color: var(--light-blue);
  padding-top: clamp(2.8941176471rem, 6.0294117647vw, 5.125rem);
  padding-bottom: clamp(4.2352941176rem, 8.8235294118vw, 7.5rem);
}
@media screen and (max-width:767px) {
  .flow {
    background-color: white;
    padding-top: 0;
    padding-bottom: 10.6666666667vw;
  }
}

.flow__title {
  font-size: clamp(2.4705882353rem, 5.1470588235vw, 4.375rem);
  color: var(--dark-blue);
  font-weight: bold;
  text-align: center;
  line-height: 1.3714285714;
}
@media screen and (max-width:767px) {
  .flow__title {
    font-size: 6.4vw;
  }
}

.flow__content p {
  font-size: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
  line-height: 1.5;
  text-align: center;
  color: var(--blue);
  margin-top: clamp(0.9882352941rem, 2.0588235294vw, 1.75rem);
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .flow__content p {
    margin-top: 4.2666666667vw;
    font-size: 4vw;
    text-align: left;
  }
}
.flow__content img {
  margin-top: clamp(0.8470588235rem, 1.7647058824vw, 1.5rem);
}
@media screen and (max-width:767px) {
  .flow__content img {
    padding-inline: 6.6666666667vw;
    margin-top: 6.6666666667vw;
  }
}

/* ---------------------------------------------------
 * faq
/* ---------------------------------------------------*/
.faq {
  padding-bottom: clamp(2.8235294118rem, 5.8823529412vw, 5rem);
}
@media screen and (max-width:767px) {
  .faq {
    padding-bottom: 0;
  }
}

.faq__title {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
  font-size: min(40px, 4vw);
  color: white;
  background-color: var(--blue);
  height: 80px;
  z-index: 0;
  background-image: url(../img/faq_title-icon.png);
  background-color: var(--blue);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (max-width:767px) {
  .faq__title {
    font-size: 4.8vw;
    height: 21.3333333333vw;
  }
}
.faq__title img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  content: "";
  display: block;
  width: 550px;
  height: 100%;
  z-index: 2;
  -o-object-fit: cover;
     object-fit: cover;
}