@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:wght@100..900&display=swap");
*, *::before, *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

html:focus-within {
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

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

img, picture {
  max-width: 100%;
  display: block;
}

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

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
html {
  font-size: 16px;
}
html:focus-within {
  scroll-behavior: smooth;
}

body, h1, h2, h3, h4, h5, h6, p, ol, ul, dl, table {
  margin: 0;
}

body {
  background-color: #fff;
  line-height: 1.8;
  color: #293947;
  font-family: "Noto Sans JP" , "ヒラギノ角ゴシック Pro" , "Hiragino Kaku Gothic Pro" , メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

a {
  background-color: transparent;
  color: inherit;
  text-decoration: none;
}
a:hover {
  color: inherit;
  text-decoration: none;
}
a:active {
  color: inherit;
  text-decoration: none;
}
a:visited {
  color: inherit;
  text-decoration: none;
}

b, strong {
  font-weight: bolder;
}

small {
  font-size: 80%;
}

audio, canvas, iframe, img, svg, video {
  vertical-align: top;
}

iframe {
  border-style: none;
}

img {
  border-style: none;
  max-width: 100%;
  height: auto;
}

ol, ul {
  list-style: none;
  padding: 0;
}

dd {
  margin-left: 0;
}

table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
  background-color: #fff;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}
.site-header__container {
  /* max-width: 1200px; *//* 必要に応じて */
  margin: 0 auto;
  /* padding: 10px 20px;*/
  box-sizing: border-box;
}
 
/* ヘッダーがかぶらないように上部余白を付ける */
body {
  margin-top: 80px; /* ヘッダーの高さに応じて調整（例：60〜100px） */
}

.site-header__container {
  margin-right: auto;
  margin-left: auto;
  padding-right: 0.625rem;
  padding-left: 0.625rem;
}
.site-header__logo a {
  display: block;
}
.site-header__contact-tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 0.3125rem;
  font-weight: 900;
}
.site-header__contact-number {
  line-height: 1;
  color: #ec5228;
  font-family: "Roboto" , sans-serif;
}
.site-header__contact-time {
  line-height: 1;
  font-weight: 500;
}
.site-header__contact-button a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.5em;
     -moz-column-gap: 0.5em;
          column-gap: 0.5em;
  background-color: #ec5228;
  line-height: 1.3;
  color: #fff;
  font-weight: 700;
}
.site-header__contact-button a::before {
  content: "";
  display: inline-block;
  background: url("../img/icon-arrow.svg") 0 0 no-repeat;
  background-size: 100% 100%;
  width: 0.5em;
  aspect-ratio: 13/18;
}
@media (max-width: 767px) {
  .site-header__container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .site-header__logo {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 30%;
        -ms-flex: 0 0 30%;
            flex: 0 0 30%;
  }
  .site-header__logo img {
    width: 100%;
  }
  .site-header__contact {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 70%;
        -ms-flex: 0 0 70%;
            flex: 0 0 70%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 0.3125rem;
       -moz-column-gap: 0.3125rem;
            column-gap: 0.3125rem;
  }
  .site-header__contact-number {
    font-size: 0.9375rem;
    white-space: nowrap;
  }
  .site-header__contact-time {
    font-size: 0.625rem;
  }
  .site-header__contact-button {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 7.5rem;
        -ms-flex: 0 0 7.5rem;
            flex: 0 0 7.5rem;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
  }
  .site-header__contact-button a {
    width: 100%;
    height: 2.5rem;
    font-size: 0.75rem;
    border-radius: 1.25rem;
  }
}


@media (min-width: 768px) {
  .site-header__container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 2.5rem;
       -moz-column-gap: 2.5rem;
            column-gap: 2.5rem;
    padding-right: 1.25rem;
    padding-left: 1.25rem;
  }
  .site-header__logo img {
    width: auto;
    height: 2.5rem;
  }
  .site-header__contact {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 2.5rem;
       -moz-column-gap: 2.5rem;
            column-gap: 2.5rem;
  }
  .site-header__contact-number {
    font-size: 1.875rem;
  }
  .site-header__contact-time {
    font-size: 0.75rem;
  }
  .site-header__contact-button {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
  }
  .site-header__contact-button a {
    width: 17.5rem;
    height: 3.75rem;
    font-size: 1.125rem;
    border-radius: 1.875rem;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .site-header__contact-button a:hover {
    opacity: 0.7;
  }
}
.site-footer__upper {
  background-color: #f6f7f8;
}
.site-footer__lower {
  background-color: #33664a;
}
@media (max-width: 767px) {
  .site-footer__upper {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }
  .site-footer__lower {
    padding-top: 0.625rem;
    padding-bottom: 0.625rem;
  }
}
@media (min-width: 768px) {
  .site-footer__upper {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
    text-align: center;
  }
  .site-footer__lower {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}

.footer-title {
  line-height: 1;
  font-weight: 700;
  text-align: center;
}
@media (max-width: 767px) {
  .footer-title {
    margin-bottom: 1.5em;
    font-size: 1.125rem;
  }
}
@media (min-width: 768px) {
  .footer-title {
    margin-bottom: 1.5em;
    font-size: 1.25rem;
  }
}

@media (max-width: 767px) {
  .footer-data {
    display: grid;
    grid-template-columns: 25% auto;
    row-gap: 1em;
    line-height: 1.5;
    font-size: 0.75rem;
  }
  .footer-data img {
    width: 4.375rem;
  }
}
@media (min-width: 768px) {
  .footer-data {
    display: inline-grid;
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 1em;
       -moz-column-gap: 1em;
            column-gap: 1em;
    row-gap: 0.5em;
    font-size: 0.875rem;
    text-align: left;
  }
  .footer-data img {
    width: 5rem;
  }
  .footer-data dt {
    text-align: right;
  }
}

.footer-pagetop {
  position: fixed;
}
@media (max-width: 767px) {
  .footer-pagetop {
    right: 0.625rem;
    bottom: 0.625rem;
  }
  .footer-pagetop img {
    width: 2.75rem;
    height: 2.75rem;
  }
}
@media (min-width: 768px) {
  .footer-pagetop {
    right: 2.5rem;
    bottom: 2.5rem;
  }
  .footer-pagetop img {
    width: 3.125rem;
    height: 3.125rem;
  }
}

.footer-copyright {
  line-height: 1;
  text-align: center;
  color: #fff;
}
@media (max-width: 767px) {
  .footer-copyright {
    font-size: 0.625rem;
  }
}
@media (min-width: 768px) {
  .footer-copyright {
    font-size: 0.75rem;
  }
}

.btn-action {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.5em;
     -moz-column-gap: 0.5em;
          column-gap: 0.5em;
  border: 1px solid #ef822d;
  background-color: #ec5228;
  padding-right: 1em;
  padding-left: 1em;
  line-height: 1.3;
  color: #fff !important;
  -webkit-text-decoration: !important;
          text-decoration: !important;
  font-weight: bold;
  -webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
}
.btn-action::before {
  content: "";
  display: inline-block;
  background: url("../img/icon-arrow.svg") 0 0 no-repeat;
  background-size: 100% 100%;
  width: 0.5em;
  aspect-ratio: 13/18;
}
@media (max-width: 767px) {
  .btn-action {
    height: 5rem;
    border-radius: 2.5rem;
    font-size: 1.5rem;
  }
}
@media (min-width: 768px) {
  .btn-action {
    height: 6.25rem;
    border-radius: 3.125rem;
    font-size: 2.25rem;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .btn-action:hover {
    opacity: 0.7;
  }
}

.text-slash {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-column-gap: 0.4em;
     -moz-column-gap: 0.4em;
          column-gap: 0.4em;
  line-height: 1.3;
  font-weight: 900;
  color: #fff;
  text-align: center;
}
.text-slash::before, .text-slash::after {
  content: "";
  display: block;
  min-height: 1em;
  aspect-ratio: 17/40;
}
.text-slash::before {
  background: url("../img/bg-slash-left.svg") 0 0 no-repeat;
  background-size: 100% 100%;
}
.text-slash::after {
  background: url("../img/bg-slash-right.svg") 0 0 no-repeat;
  background-size: 100% 100%;
}
.text-slash span {
  display: inline-block;
}
.text-slash strong {
  color: #ff0;
}
@media (max-width: 767px) {
  .text-slash {
    font-size: 1.125rem;
  }
  .text-slash::before, .text-slash::after {
    width: 1.0625rem;
  }
}
@media (min-width: 768px) {
  .text-slash {
    font-size: 1.75rem;
  }
  .text-slash::before, .text-slash::after {
    width: 1.0625rem;
  }
}

.mainvisual {
  background: url("../img/bg-green.png") 0 0 repeat;
  text-align: center;
  color: #fff;
}
.mainvisual__copy {
  font-weight: 300;
}
.mainvisual__logo {
  text-align: center;
}
.mainvisual__logo img {
  display: inline;
}
@media (max-width: 767px) {
  .mainvisual {
    margin-bottom: 1.875rem;
  }
  .mainvisual__inner {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }
  .mainvisual__copy {
    margin-bottom: 1.25rem;
    line-height: 1.3;
    font-size: 1.125rem;
  }
  .mainvisual__logo {
    margin-bottom: 1.25rem;
    width: 100%;
  }
  .mainvisual__logo img {
    width: 100%;
  }
  .mainvisual__button-text {
    margin-bottom: 1.25rem;
  }
  .mainvisual__button a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
@media (min-width: 768px) {
  .mainvisual {
    margin-bottom: 3.125rem;
  }
  .mainvisual__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-top: 1.875rem;
    padding-bottom: 1.875rem;
    min-height: 28.125rem;
  }
  .mainvisual__copy {
    font-size: 1.6875rem;
  }
  .mainvisual__logo {
    width: 100%;
  }
  .mainvisual__logo img {
    width: auto;
    height: 7.5rem;
  }
  .mainvisual__button a {
    width: 100%;
    max-width: 37.5rem;
  }
}

.achievement__number {
  background: url("../img/bg-achievements.jpg") center center no-repeat;
  background-size: 100% 100%;
  color: #ec5228;
  font-weight: 700;
  text-align: center;
}
.achievement__number-inner {
  aspect-ratio: 928/312;
}
.achievement__number-inner dd small {
  font-size: 40%;
}
.achievement__text {
  font-weight: 700;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .achievement {
    margin-bottom: 2.5rem;
  }
  .achievement__number {
    height: 100%;
  }
  .achievement__number-inner {
    line-height: 1;
  }
  .achievement__number-inner dt {
    font-size: 1.375rem;
  }
  .achievement__number-inner dd {
    font-size: 5rem;
  }
  .achievement__text {
    margin-top: 1em;
    line-height: 1.5;
    text-align: center;
    font-size: 1.375rem;
  }
}
@media (min-width: 768px) {
  .achievement {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 3.3333333333%;
       -moz-column-gap: 3.3333333333%;
            column-gap: 3.3333333333%;
    margin-right: auto;
    margin-bottom: 5rem;
    margin-left: auto;
    width: 100%;
    max-width: 68.9375rem;
    min-height: 9.6875rem;
    line-height: 1;
  }
  .achievement__number {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 41.9764279238%;
        -ms-flex: 0 0 41.9764279238%;
            flex: 0 0 41.9764279238%;
    height: 100%;
  }
  .achievement__number-inner {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
  }
  .achievement__number-inner dt {
    font-size: 1.5625rem;
  }
  .achievement__number-inner dd {
    font-size: 6.25rem;
  }
  .achievement__text {
    font-size: 1.875rem;
  }
}

.logo-scroll {
  overflow: hidden;
}
.logo-scroll__wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden;
}
.logo-scroll__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-animation: infinityScroll 60s infinite linear 0.5s both;
          animation: infinityScroll 60s infinite linear 0.5s both;
}
.logo-scroll__item {
  aspect-ratio: 220/100;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.logo-scroll__item img {
  max-width: 100%;
  max-height: 100%;
}
@media (max-width: 767px) {
  .logo-scroll {
    margin-bottom: 2.5rem;
  }
  .logo-scroll__inner {
    width: 150rem;
  }
  .logo-scroll__item {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 9.375rem;
        -ms-flex: 0 0 9.375rem;
            flex: 0 0 9.375rem;
  }
}
@media (min-width: 768px) {
  .logo-scroll {
    margin-bottom: 6.25rem;
  }
  .logo-scroll__wrapper {
    width: 440rem;
  }
  .logo-scroll__inner {
    width: 220rem;
  }
  .logo-scroll__item {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 13.75rem;
        -ms-flex: 0 0 13.75rem;
            flex: 0 0 13.75rem;
  }
}

@-webkit-keyframes infinityScroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes infinityScroll {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.intro-heading__inner {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: auto;
  margin-left: auto;
  background: url("../img/bg-intro-title.svg") center center no-repeat;
  line-height: 1.3;
  font-weight: 700;
  aspect-ratio: 730/143;
  text-align: center;
}
@media (max-width: 767px) {
  .intro-heading {
    margin-bottom: 1.25rem;
  }
  .intro-heading__inner {
    background-size: 100% 100%;
    padding-right: 3em;
    padding-left: 3em;
    font-size: 1.25rem;
  }
  .intro-heading__person01, .intro-heading__person02 {
    position: absolute;
    bottom: 0;
    width: auto;
    height: 7.5rem;
  }
  .intro-heading__person01 {
    left: 0;
  }
  .intro-heading__person02 {
    right: 0;
  }
}
@media (min-width: 768px) {
  .intro-heading {
    margin-bottom: 1.875rem;
  }
  .intro-heading__inner {
    background-size: 100% 100%;
    padding-right: 3em;
    padding-left: 3em;
    width: 60.8333333333%;
    font-size: 2.5rem;
  }
  .intro-heading__person01, .intro-heading__person02 {
    position: absolute;
    bottom: 0;
    width: auto;
    height: 15rem;
  }
  .intro-heading__person01 {
    left: -10%;
  }
  .intro-heading__person02 {
    right: -10%;
  }
}

.intro-probrems {
  text-align: center;
}
.intro-probrems__image img {
  width: 100%;
}
.intro-probrems__text {
  line-height: 1.4;
  font-weight: 700;
}
@media (max-width: 767px) {
  .intro-probrems__col {
    margin-bottom: 2.5rem;
  }
  .intro-probrems__text {
    font-size: 1rem;
  }
}
@media (min-width: 768px) {
  .intro-probrems {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    -webkit-column-gap: 4%;
       -moz-column-gap: 4%;
            column-gap: 4%;
    margin-bottom: 5rem;
  }
  .intro-probrems__text {
    font-size: 1.125rem;
  }
}

.intro-box {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  border: 0.3125rem solid #fbdd9a;
  line-height: 1.8;
  font-weight: 700;
  text-align: center;
}
.intro-box__arrow {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  aspect-ratio: 285/71;
}
.intro-box__text02 {
  font-size: 150%;
  color: #ec5228;
}
@media (max-width: 767px) {
  .intro-box {
    margin-bottom: 1.875rem;
    padding: 1.875rem 0.9375rem 1.25rem 0.9375rem;
    line-height: 1.5;
    font-size: 1.25rem;
  }
  .intro-box__arrow {
    width: 12.5rem;
  }
  .intro-box__text02 {
    margin-top: 0.2em;
    margin-bottom: 0.4em;
    line-height: 1.3;
  }
}
@media (min-width: 768px) {
  .intro-box {
    margin-bottom: 5rem;
    padding: 3.75rem 0.9375rem 2.5rem 0.9375rem;
    font-size: 1.875rem;
  }
}

.spike-balloon-01 {
  background-image: url("../img/img-intro-emphasis-01.svg");
  aspect-ratio: 110/93;
  width: 3.6666666667em;
}

.spike-balloon-02 {
  background-image: url("../img/img-intro-emphasis-02.svg");
  aspect-ratio: 109/90;
  width: 3.6333333333em;
}

.spike-balloon-03 {
  background-image: url("../img/img-intro-emphasis-03.svg");
  aspect-ratio: 128/86;
  width: 4.2666666667em;
}

.spike-balloon-01,
.spike-balloon-02,
.spike-balloon-03 {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-size: 100% 100%;
  color: #fff;
}
.section-heading {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 0.5em;
  line-height: 1;
  font-weight: 700;
  text-align: center;
}
.section-heading__subtitle {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.5em;
     -moz-column-gap: 0.5em;
          column-gap: 0.5em;
  color: #3f7d58;
  font-family: "Roboto" , sans-serif;
}
.section-heading__subtitle::before, .section-heading__subtitle::after {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  min-width: 0.9375rem;
}
.section-heading__subtitle::before {
  background-image: url("../img/bg-section-heading-02-01.svg");
}
.section-heading__subtitle::after {
  background-image: url("../img/bg-section-heading-02-02.svg");
}
.section-heading__subtitle.-orange {
  color: #ef822d;
}
.section-heading__subtitle.-orange::before {
  background-image: url("../img/bg-section-heading-01-01.svg");
}
.section-heading__subtitle.-orange::after {
  background-image: url("../img/bg-section-heading-01-02.svg");
}
@media (max-width: 767px) {
  .section-heading__subtitle {
    font-size: 0.875rem;
  }
  .section-heading__title {
    font-size: 1.875rem;
  }
}
@media (min-width: 768px) {
  .section-heading__subtitle {
    font-size: 1.125rem;
  }
  .section-heading__title {
    font-size: 2.5rem;
  }
}

.section-feature {
  background: url("../img/bg-yellow.png") 0 0 repeat;
  background-size: 11.25rem auto;
}
@media (max-width: 767px) {
  .section-feature {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }
}
@media (min-width: 768px) {
  .section-feature {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}

.feature__title {
  line-height: 1.3;
  font-weight: bold;
}
.feature__image {
  aspect-ratio: 400/208;
  background-color: #fff;
  border-radius: 0.75rem;
}
.feature__image img {
  width: 100%;
}
.feature__content strong {
  font-weight: 700;
  color: #ec5228;
}
@media (max-width: 767px) {
  .feature {
    margin-top: 2.5rem;
  }
  .feature + .feature {
    margin-top: 1.875rem;
  }
  .feature__title {
    font-size: 1.25rem;
  }
  .feature__image {
    margin-top: 0.9375rem;
    margin-bottom: 0.9375rem;
  }
  .feature__content {
    line-height: 1.8;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .feature {
    display: grid;
    grid-template-columns: 33.3333333333% auto;
    grid-template-rows: auto auto;
    -webkit-column-gap: 1.5625rem;
       -moz-column-gap: 1.5625rem;
            column-gap: 1.5625rem;
    row-gap: 1.5625rem;
    margin-top: 3.125rem;
  }
  .feature + .feature {
    margin-top: 2.5rem;
  }
  .feature__title {
    grid-column: 1/3;
    grid-row: 1/2;
    font-size: 1.6875rem;
  }
  .feature__image {
    grid-column: 1/2;
    grid-row: 2/3;
  }
  .feature__content {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    grid-column: 2/3;
    grid-row: 2/3;
    line-height: 1.8;
    font-size: 1rem;
  }
}

.section-plan {
  background: url("../img/bg-star.svg") center center repeat-y;
}
@media (max-width: 767px) {
  .section-plan {
    background-size: 100% auto;
    padding-top: 2.5rem;
    padding-bottom: 3.75rem;
  }
}
@media (min-width: 768px) {
  .section-plan {
    background-size: 132.5rem auto;
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}

.plan-table {
  border: 1px solid #8f9396;
  background-color: #fff;
  line-height: 1.5;
}
.plan-table th,
.plan-table td {
  padding: 0.9375rem 0.9375rem;
}
.plan-table th {
  background-color: #f5f7f7;
  font-weight: normal;
}
.plan-table thead {
  font-weight: 700;
}
.plan-table thead th,
.plan-table thead td {
  border-bottom: 1px solid #8f9396;
  border-left: 1px solid #8f9396;
  text-align: center;
}
.plan-table thead .td01 {
  background-color: #379e68;
  color: #fff;
}
.plan-table thead .td02 {
  background-color: #33664a;
  color: #fff;
}
.plan-table tbody th,
.plan-table tbody td {
  border-bottom: 1px solid #dddfdf;
  border-left: 1px solid #8f9396;
}
.plan-table tbody th {
  text-align: left;
}
.plan-table tbody td {
  text-align: center;
}
.plan-table tfoot th,
.plan-table tfoot td {
  border-top: 1px solid #dddfdf;
  border-left: 1px solid #8f9396;
}
.plan-table tfoot th {
  text-align: left;
}
.plan-table tfoot td {
  text-align: center;
  font-weight: bold;
}
.plan-table tfoot td small {
  display: block;
}
.plan-table .c01 {
  color: #379e68;
}
@media (max-width: 767px) {
  .plan-table {
    margin-top: 2.5rem;
    font-size: 0.75rem;
  }
  .plan-table th,
  .plan-table td {
    padding: 0.375rem 0.375rem;
  }
  .plan-table tfoot td strong {
    font-size: 150%;
  }
  .plan-table tfoot td small {
    font-size: 0.75rem;
  }
}
@media (min-width: 768px) {
  .plan-table {
    margin-top: 5rem;
  }
  .plan-table tfoot td {
    font-size: 1.25rem;
  }
  .plan-table tfoot td strong {
    font-size: 150%;
  }
  .plan-table tfoot td small {
    font-size: 1rem;
  }
}

.action {
  position: relative;
  background: url("../img/bg-green.png") 0 0 repeat;
  background-size: 11.25rem auto;
}
.action__spike {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background: url("../img/bg-jaggy.svg") center center no-repeat;
  background-size: 100% 100%;
  line-height: 1.3;
  font-weight: 900;
  color: #ff0;
}
.action__text-slash {
  position: relative;
  z-index: 1;
  letter-spacing: 0.05em;
}
.action__lgtext {
  position: relative;
  z-index: 1;
  line-height: 1.3;
  text-align: center;
  color: #fff;
  font-weight: 900;
}
.action__bg01 {
  background-image: url("../img/img-action-01.png"), url("../img/img-action-02.png");
  background-repeat: no-repeat;
}
.action__bg02 {
  position: relative;
}
.action__bg02::before, .action__bg02::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
}
.action__bg02::before {
  background-image: url("../img/img-action-01.png");
  aspect-ratio: 545/660;
}
.action__bg02::after {
  background-image: url("../img/img-action-02.png");
  aspect-ratio: 535/660;
}
@media (max-width: 767px) {
  .action .container {
    padding-bottom: 1.25rem;
  }
  .action__spike {
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 80%;
    aspect-ratio: 398/100;
    font-size: 1.375rem;
  }
  .action__button {
    margin-top: 1.875rem;
  }
  .action__button a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-right: auto;
    margin-left: auto;
    max-width: 37.5rem;
    max-height: 6.25rem;
    border-radius: 3.125rem;
  }
  .action__lgtext {
    margin-bottom: 0.625rem;
    padding-top: 2.5rem;
    font-size: 1.875rem;
  }
  .action__bg01 {
    background-position: left -20% bottom, right -20% bottom;
    background-size: auto 12.5rem, auto 12.5rem;
  }
  .action__bg01 .container {
    padding-top: 3.75rem;
  }
  .action__bg02 {
    padding-bottom: 1.875rem;
  }
  .action__bg02::before, .action__bg02::after {
    top: -20%;
    z-index: 2;
    width: auto;
    height: 6.25rem;
  }
  .action__bg02::before {
    left: 0;
  }
  .action__bg02::after {
    right: 0;
  }
}
@media (min-width: 768px) {
  .action .container {
    padding-bottom: 3.125rem;
  }
  .action__spike {
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    min-width: 24.875rem;
    min-height: 6.25rem;
    font-size: 2.25rem;
  }
  .action__button {
    margin-top: 3.125rem;
  }
  .action__button a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin-right: auto;
    margin-left: auto;
    max-width: 37.5rem;
    max-height: 6.25rem;
    border-radius: 3.125rem;
  }
  .action__lgtext {
    margin-bottom: 1.5625rem;
    padding-top: 5.625rem;
    font-size: 3.125rem;
  }
  .action__bg01 {
    background-position: left calc(50% - min(37.5rem, 40vw)) bottom, right calc(50% - min(37.5rem, 40vw)) bottom;
    background-size: auto 20.625rem, auto 20.625rem;
    height: 20.625rem;
  }
  .action__bg01 .container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    height: 100%;
  }
  .action__bg02 {
    min-height: 17.5rem;
  }
  .action__bg02::before, .action__bg02::after {
    top: -3.125rem;
    width: auto;
    height: 20.625rem;
  }
  .action__bg02::before {
    left: 0;
  }
  .action__bg02::after {
    right: 0;
  }
}

.recommend__item {
  position: relative;
  background-color: #fff;
}
.recommend__check {
  position: absolute;
  top: 0;
  left: 0;
}
.recommend__text {
  line-height: 1.7;
  text-align: center;
  font-weight: 700;
}
@media (max-width: 767px) {
  .recommend {
    padding-right: 0.9375rem;
    padding-left: 0.9375rem;
  }
  .recommend__item {
    margin-bottom: 1.25rem;
    border-radius: 0.75rem;
    padding-bottom: 0.9375rem;
  }
  .recommend__check {
    top: -0.9375rem;
    left: -0.9375rem;
    width: 3.75rem;
    height: 3.75rem;
  }
  .recommend__image {
    overflow: hidden;
    border-radius: 0.75rem;
  }
  .recommend__text {
    line-height: 1.5;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .recommend {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    -webkit-column-gap: 4%;
       -moz-column-gap: 4%;
            column-gap: 4%;
  }
  .recommend__item {
    border-radius: 0.75rem;
    padding-bottom: 1.875rem;
  }
  .recommend__check {
    top: -1.25rem;
    left: -1.25rem;
    width: 5rem;
    height: 5rem;
  }
  .recommend__image {
    overflow: hidden;
    border-radius: 0.75rem;
  }
  .recommend__text {
    padding-right: 0.9375rem;
    padding-left: 0.9375rem;
    font-size: 1.125rem;
  }
}

.section-flow {
  background-color: #f9f8f8;
}
@media (max-width: 767px) {
  .section-flow {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }
}
@media (min-width: 768px) {
  .section-flow {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}

.flow__heading {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.75em;
     -moz-column-gap: 0.75em;
          column-gap: 0.75em;
  background-color: #ef822d;
  color: #fff;
  font-weight: bold;
}
.flow__heading-num {
  font-family: "Roboto" , sans-serif;
}
.flow__content {
  background-color: #fff;
}
@media (max-width: 767px) {
  .flow {
    margin-top: 2.5rem;
  }
  .flow__item {
    position: relative;
    border-radius: 0.375rem;
  }
  .flow__item::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -1.9375rem;
    background: url("../img/img-flow-arrow.svg") center center no-repeat;
    background-size: 100% 100%;
    aspect-ratio: 39/37;
    -webkit-transform: translate(-50%, 50%);
            transform: translate(-50%, 50%);
    width: 2.4375rem;
    height: 2.3125rem;
  }
  .flow__item + .flow__item {
    margin-top: 3.875rem;
  }
  .flow__item:last-child::after {
    display: none;
  }
  .flow__heading {
    position: relative;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0.5em 1em;
    border-radius: 0.375rem 0.375rem 0 0;
    line-height: 1;
  }
  .flow__heading-num {
    font-size: 2.5rem;
  }
  .flow__heading-text {
    font-size: 1.125rem;
  }
  .flow__content {
    padding: 1em;
    border-radius: 0 0 0.375rem 0.375rem;
  }
}
@media (min-width: 768px) {
  .flow {
    margin-top: 5rem;
  }
  .flow__item {
    display: grid;
    grid-template-columns: 33.3333333333% auto;
    min-height: 5rem;
  }
  .flow__item + .flow__item {
    margin-top: 3.875rem;
  }
  .flow__item:last-child .flow__heading::after {
    display: none;
  }
  .flow__heading {
    position: relative;
    padding-right: 5%;
    padding-left: 10%;
    border-radius: 0.375rem 0 0 0.375rem;
    line-height: 1;
  }
  .flow__heading::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -1.9375rem;
    background: url("../img/img-flow-arrow.svg") center center no-repeat;
    background-size: 100% 100%;
    aspect-ratio: 39/37;
    -webkit-transform: translate(-50%, 50%);
            transform: translate(-50%, 50%);
    width: 2.4375rem;
    height: 2.3125rem;
  }
  .flow__heading-num {
    font-size: 2.5rem;
  }
  .flow__heading-text {
    font-size: 1.125rem;
  }
  .flow__content {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    padding-right: 1em;
    padding-left: 1em;
    border-radius: 0 0.375rem 0.375rem 0;
  }
}

.section-faq {
  background: url("../img/bg-star.svg") center center repeat-y;
}
@media (max-width: 767px) {
  .section-faq {
    background-size: 100% auto;
    padding-top: 2.5rem;
    padding-bottom: 5rem;
  }
}
@media (min-width: 768px) {
  .section-faq {
    background-size: 132.5rem auto;
    padding-top: 5rem;
    padding-bottom: 7.5rem;
  }
}

.faq-list__item {
  background-color: #f5f7f7;
  border-radius: 0.75rem;
}
.faq-list__q {
  position: relative;
}
.faq-list__q::after {
  content: "";
  position: absolute;
  right: 0;
  background: url("../img/icon-faq-plus.svg") 0 0 no-repeat;
  background-size: 100% 100%;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.faq-list__q.is-active::after {
  background: url("../img/icon-faq-minus.svg") 0 0 no-repeat;
  background-size: 100% 100%;
}
.faq-list__q-text {
  font-weight: 700;
}
.faq-list__a {
  display: none;
}
.faq-list__a-inner {
  background-color: #fff;
  border-radius: 0.75rem;
}
@media (max-width: 767px) {
  .faq-list {
    margin-top: 2.5rem;
  }
  .faq-list__item {
    margin-bottom: 1.25rem;
    padding: 0.625rem 0.9375rem;
  }
  .faq-list__item:last-child {
    margin-bottom: 0;
  }
  .faq-list__q-icon, .faq-list__a-icon {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 2.5rem;
        -ms-flex: 0 0 2.5rem;
            flex: 0 0 2.5rem;
  }
  .faq-list__q-icon img, .faq-list__a-icon img {
    width: 2.5rem;
    height: 2.5rem;
  }
  .faq-list__q, .faq-list__a-inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 0.625rem;
       -moz-column-gap: 0.625rem;
            column-gap: 0.625rem;
  }
  .faq-list__q {
    padding-right: 1.875rem;
  }
  .faq-list__q::after {
    top: 0.7em;
    width: 1.25rem;
    height: 1.25rem;
  }
  .faq-list__q-text {
    padding-top: 0.5em;
    line-height: 1.5;
    font-size: 1rem;
  }
  .faq-list__a-inner {
    margin-top: 0.9375rem;
    padding: 0.625rem 0.9375rem;
  }
  .faq-list__a-text {
    padding-top: 0.4em;
    font-size: 0.875rem;
  }
}
@media (min-width: 768px) {
  .faq-list {
    margin-top: 5rem;
  }
  .faq-list__item {
    margin-bottom: 2.5rem;
    padding: 1.25rem 2.5rem;
  }
  .faq-list__item:last-child {
    margin-bottom: 0;
  }
  .faq-list__q-icon, .faq-list__a-icon {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 2.75rem;
        -ms-flex: 0 0 2.75rem;
            flex: 0 0 2.75rem;
  }
  .faq-list__q-icon img, .faq-list__a-icon img {
    width: 2.75rem;
    height: 2.75rem;
  }
  .faq-list__q, .faq-list__a-inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 1.25rem;
       -moz-column-gap: 1.25rem;
            column-gap: 1.25rem;
  }
  .faq-list__q {
    padding-right: 2.375rem;
  }
  .faq-list__q::after {
    top: 0.6em;
    width: 1.75rem;
    height: 1.75rem;
  }
  .faq-list__q-text {
    padding-top: 0.3em;
    font-size: 1.125rem;
    cursor: pointer;
  }
  .faq-list__a-inner {
    margin-top: 1.25rem;
    padding: 1.25rem 2.5rem;
  }
  .faq-list__a-text {
    padding-top: 0.4em;
  }
}

.container {
  margin-right: auto;
  margin-left: auto;
  padding-right: 0.9375rem;
  padding-left: 0.9375rem;
}
@media (min-width: 768px) {
  .container {
    max-width: 75rem;
  }
}
@media (min-width: 76.875rem) {
  .container {
    padding-right: 0;
    padding-left: 0;
  }
}

.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-block {
  display: block !important;
}

@media (min-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-block {
    display: block !important;
  }
}
@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-block {
    display: block !important;
  }
}
@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-block {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-block {
    display: block !important;
  }
}
@media (min-width: 1400px) {
  .d-xxl-none {
    display: none !important;
  }
  .d-xxl-inline {
    display: inline !important;
  }
  .d-xxl-block {
    display: block !important;
  }
}