@charset "UTF-8";
@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");
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol, ul, li {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption, th, td {
  text-align: left;
  font-weight: inherit;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}

q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
  display: block;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

a,
button {
  text-decoration: none;
  -webkit-transition: opacity 0.3s ease, color 0.3s ease, background-color 0.3s ease, background-image 0.3s ease, background 0.3s ease;
  transition: opacity 0.3s ease, color 0.3s ease, background-color 0.3s ease, background-image 0.3s ease, background 0.3s ease;
  color: #000;
}
@media (any-hover: hover) {
  a:hover,
  button:hover {
    opacity: 0.7;
  }
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  img {
    width: 100%;
  }
}

table {
  width: 100%;
}

input[type=text],
input[type=email],
input[type=tel],
input[type=submit],
textarea {
  -webkit-appearance: none;
  border: none;
  font-family: inherit;
  border-radius: 0;
}

input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus {
  outline: 0;
}

textarea {
  resize: vertical;
}
textarea:focus {
  outline: none;
}

::-webkit-input-placeholder {
  color: #767676;
}

::-moz-placeholder {
  color: #767676;
}

:-ms-input-placeholder {
  color: #767676;
}

::-ms-input-placeholder {
  color: #767676;
}

::placeholder {
  color: #767676;
}

p {
  line-break: strict;
}

/* ---------------------------------------
  html , body
-----------------------------------------*/
html {
  font-size: 62.5%;
}
@media screen and (max-width: 1200px) {
  html {
    font-size: 0.8333333333vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 1.3333333333vw;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: #000;
  -webkit-text-size-adjust: 100%;
  overflow-y: auto;
  position: relative;
  padding-bottom: 12rem;
}
@media screen and (max-width: 1200px) {
  body {
    overflow-x: auto;
  }
}
@media screen and (max-width: 767px) {
  body {
    overflow-x: hidden;
    padding-bottom: 18.2rem;
  }
}
body.active {
  overflow: hidden;
}

/* ---------------------------------------
  font
-----------------------------------------*/
.font_roboto {
  font-family: "Roboto", sans-serif;
}

/* ---------------------------------------
  .wrap
-----------------------------------------*/
.wrap {
  width: 100rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .wrap {
    width: 68.8rem;
  }
}

/* ---------------------------------------
  header
-----------------------------------------*/
header {
  width: 100%;
  height: 10rem;
  background-color: #fff;
  -webkit-box-shadow: 7px 7px 5px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 7px 7px 5px 0px rgba(0, 0, 0, 0.08);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-line-pack: center;
      align-content: center;
  padding: 0 3rem;
}
@media screen and (max-width: 767px) {
  header {
    -webkit-box-shadow: 5px 5px 3px 0px rgba(0, 0, 0, 0.08);
            box-shadow: 5px 5px 3px 0px rgba(0, 0, 0, 0.08);
  }
}
header .logo_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2.2rem;
}
@media screen and (max-width: 767px) {
  header .logo_box {
    gap: 0 2.5rem;
  }
}
header .logo {
  width: 23.5rem;
}
@media screen and (max-width: 767px) {
  header .logo {
    max-width: none;
  }
}
header .caption {
  font-size: 1.4rem;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  header .caption {
    font-size: 1.9rem;
    line-height: 1.5263157895;
  }
}
header .contact_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.9rem;
}
@media screen and (max-width: 767px) {
  header .contact_list {
    display: none;
  }
}
header .contact_list .tel .tel_link {
  width: 27.8rem;
  height: 6rem;
  border-radius: 3rem;
  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;
  gap: 0 0.9rem;
  background-color: #00a096;
}
header .contact_list .tel .icon {
  width: 3rem;
}
header .contact_list .tel .tel_text {
  font-size: 2.7rem;
  font-weight: 900;
  color: #fff;
}
header .contact_list .tel .time {
  font-size: 1rem;
  font-weight: 500;
  color: #fff;
}
header .contact_list .mail a {
  width: 23rem;
  height: 6rem;
  border-radius: 3rem;
  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;
  gap: 0 0.9rem;
  background-color: #ff5b00;
}
header .contact_list .mail .icon {
  width: 2.2rem;
}
header .contact_list .mail .txt {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
}

/* ---------------------------------------
  footer
-----------------------------------------*/
footer .footer_wrap {
  width: 100%;
  padding: 3rem 2.4rem 3rem;
  background-color: #00a096;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
footer .copyright {
  font-size: 1.4rem;
  color: #fff;
}
@media screen and (max-width: 767px) {
  footer .copyright {
    font-size: 1.8rem;
  }
}
footer .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
footer .link li {
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  footer .link li {
    font-size: 2rem;
  }
}
footer .link li a {
  color: #fff;
}
footer .link li:nth-of-type(n+2) {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
}
footer .link li:nth-of-type(n+2)::before {
  content: "｜";
  display: block;
  margin: 0 1.3rem;
}
@media screen and (max-width: 767px) {
  footer .link li:nth-of-type(n+2)::before {
    margin: 0;
  }
}

.flow_box {
  background-color: #383838;
  width: 100%;
  height: 12rem;
  position: fixed;
  bottom: 0;
  left: 0;
  padding: 1rem 0;
  z-index: 99;
  -webkit-transition: 0.3;
  transition: 0.3;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .flow_box {
    padding: 1.4rem 2rem;
    height: 18.2rem;
  }
}
.flow_box .wrap {
  background-color: #fff;
  padding: 1rem 1.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .flow_box .wrap {
    width: 71rem;
    max-width: none;
    padding: 1.9rem 2.5rem 1.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media screen and (max-width: 767px) {
  .flow_box .txt_box {
    width: 100%;
    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;
  }
}
.flow_box .txt01 {
  font-size: 2.3rem;
  font-weight: 700;
  color: #00a096;
  padding: 0 1.5rem;
  position: relative;
  margin-left: 1.5rem;
}
@media screen and (max-width: 767px) {
  .flow_box .txt01 {
    font-size: 2.6rem;
    padding: 0 3rem 0 2rem;
    margin-left: 0;
  }
}
.flow_box .txt01::before, .flow_box .txt01::after {
  content: "";
  width: 2rem;
  height: 0.24rem;
  border-radius: 0.12rem;
  background-color: #00a096;
  position: absolute;
  top: 50%;
}
@media screen and (max-width: 767px) {
  .flow_box .txt01::before, .flow_box .txt01::after {
    width: 3rem;
    height: 0.28rem;
    border-radius: 0.14rem;
  }
}
.flow_box .txt01::before {
  left: -0.8rem;
  -webkit-transform: translateY(-50%) rotate(60deg);
          transform: translateY(-50%) rotate(60deg);
}
.flow_box .txt01::after {
  right: 1.5rem;
  -webkit-transform: translateY(-50%) rotate(-60deg);
          transform: translateY(-50%) rotate(-60deg);
}
@media screen and (max-width: 767px) {
  .flow_box .txt01::after {
    right: 0;
  }
}
@media screen and (max-width: 767px) {
  .flow_box .txt01 span {
    background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
    background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
  }
}
.flow_box .txt02 {
  font-size: 2.1rem;
  font-weight: 700;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .flow_box .txt02 {
    font-size: 2.1rem;
    margin-top: 0;
    margin-left: 1rem;
  }
}
.flow_box .txt02 span {
  font-size: 2.6rem;
  color: #ff4343;
}
@media screen and (min-width: 768px) {
  .flow_box .txt02 span {
    background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
    background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
  }
}
@media screen and (max-width: 767px) {
  .flow_box .txt02 span {
    font-size: 2.6rem;
  }
}
.flow_box .contact_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.1rem;
}
@media screen and (max-width: 767px) {
  .flow_box .contact_list {
    width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  .flow_box .contact_list .tel .tel_link {
    width: 33rem;
    height: 7.8rem;
    border-radius: 3.9rem;
    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;
    gap: 0 1.4rem;
    background-color: #00a096;
  }
}
@media screen and (max-width: 767px) {
  .flow_box .contact_list .tel .tel_link a {
    width: 33rem;
    height: 7.8rem;
    border-radius: 3.9rem;
    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;
    gap: 0 1.4rem;
    background-color: #00a096;
  }
}
.flow_box .contact_list .tel .icon {
  width: 4.1rem;
}
.flow_box .contact_list .tel .tel_text {
  font-size: 3rem;
  font-weight: 900;
  color: #fff;
}
.flow_box .contact_list .tel .time {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
}
.flow_box .contact_list .mail a {
  width: 31.6rem;
  height: 7.8rem;
  border-radius: 3.9rem;
  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;
  gap: 0 1.4rem;
  background-color: #ff5b00;
}
.flow_box .contact_list .mail .icon {
  width: 3rem;
}
.flow_box .contact_list .mail .txt {
  font-size: 2.7rem;
  font-weight: 700;
  color: #fff;
}
.flow_box.active {
  opacity: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

/* ---------------------------------------
  #mv
-----------------------------------------*/
#mv {
  background: url(../img/bg_main.png) repeat-y top/100% auto;
  padding: 5.2rem 0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #mv {
    background-image: url(../img/bg_main_sp.png);
    padding: 5.3rem 0 0;
  }
}
#mv .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
@media screen and (max-width: 767px) {
  #mv .wrap {
    width: 68.8rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#mv .txt_box {
  margin-left: -9.3rem;
}
@media screen and (max-width: 1200px) {
  #mv .txt_box {
    margin-left: -6rem;
  }
}
@media screen and (max-width: 767px) {
  #mv .txt_box {
    margin-left: 0;
  }
}
#mv .ttl_caption {
  background: -webkit-gradient(linear, left top, right top, from(rgb(194, 21, 0)), color-stop(17%, rgb(203, 46, 0)), to(rgb(255, 197, 0)));
  background: linear-gradient(90deg, rgb(194, 21, 0) 0%, rgb(203, 46, 0) 17%, rgb(255, 197, 0) 100%);
  font-size: 3.1rem;
  font-weight: 700;
  color: #fff;
  padding: 1.2rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .ttl_caption {
    font-size: 3.1rem;
    padding: 1.2rem;
    margin: 0 auto;
  }
}
#mv .ttl {
  font-size: 5.2rem;
  font-weight: 700;
  color: #cb2e00;
  margin-top: 1.2rem;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .ttl {
    font-size: 4.5rem;
    margin-top: 2.6rem;
    text-align: center;
  }
}
#mv .ttl .txt120p {
  font-size: 120%;
}
#mv .ttl .txt130p {
  font-size: 130%;
}
#mv .lead {
  font-size: 2.7rem;
  font-weight: 700;
  line-height: 1.5185185185;
  margin-top: 1.6rem;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .lead {
    font-size: 2.7rem;
    text-align: center;
    margin-top: 2.8rem;
  }
}
#mv .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 1.2rem;
  margin-top: 4.8rem;
}
@media screen and (max-width: 767px) {
  #mv .list {
    gap: 0;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 4.8rem;
  }
}
#mv .list li {
  width: 24.2rem;
  background-color: #fff;
  position: relative;
  padding: 1.2rem 1.5rem 2.2rem;
  -webkit-box-shadow: 6px 6px 3px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 6px 6px 3px 0px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 767px) {
  #mv .list li {
    width: 22.2rem;
    padding: 3.2rem 1.7rem 2.1rem;
  }
}
@media screen and (max-width: 767px) {
  #mv .list li:nth-of-type(3) .list_txt {
    padding-top: 0.8rem;
  }
}
#mv .list .list_point {
  font-size: 1.7rem;
  font-weight: 700;
  padding: 0.5rem;
  background-color: #ffec00;
  color: #cb2e00;
  position: absolute;
  left: 50%;
  top: -2.2rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .list .list_point {
    font-size: 2rem;
    padding: 0.7rem 1rem;
    top: -1.7rem;
  }
}
#mv .list .list_point::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  border-top: 7px solid #ffec00;
  border-bottom: 0;
  position: absolute;
  left: 50%;
  bottom: -5px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#mv .list .list_ttl {
  font-size: 2.4rem;
  font-weight: 700;
  color: #cb2e00;
  text-align: center;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .list .list_ttl {
    font-size: 3rem;
  }
}
#mv .list .list_txt {
  margin-top: 2.7rem;
  position: relative;
  font-size: 1.7rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5882352941;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
}
@media screen and (max-width: 767px) {
  #mv .list .list_txt {
    margin-top: 2.7rem;
    font-size: 2rem;
    line-height: 1.2;
  }
}
#mv .list .list_txt::before {
  content: "";
  width: 20rem;
  height: 3px;
  border-radius: 1.5px;
  background-color: #cb2e00;
  position: absolute;
  top: -1.5rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  #mv .list .list_txt::before {
    width: 18.3rem;
    height: 2px;
    border-radius: 1px;
    top: -1.5rem;
  }
}
#mv .btn_box {
  margin-top: 3.3rem;
}
#mv .btn_box a {
  width: 30.3rem;
  height: 6.4rem;
  border-radius: 3.2rem;
  background-color: #ff5b00;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1.9rem;
  font-weight: 700;
  color: #fff;
}
#mv .img_box {
  position: absolute;
  right: -34.5rem;
  bottom: -18.5rem;
  width: 86.6rem;
}
@media screen and (max-width: 767px) {
  #mv .img_box {
    position: static;
    width: 100vw;
    margin-left: calc((100vw - 68.8rem) / -2);
  }
}

/* ---------------------------------------
  .sec_ttl
-----------------------------------------*/
.sec_ttl {
  padding: 4.6rem 0 3.7rem;
  text-align: center;
  color: #fff;
  font-size: 5rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  position: relative;
  line-height: 1.3;
}
.sec_ttl::before {
  content: "";
  width: 3rem;
  height: 2.6rem;
  position: absolute;
  left: 50%;
  bottom: -2.4rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.sec_ttl.green {
  background: -webkit-gradient(linear, left top, right top, from(rgb(139, 185, 41)), color-stop(46%, rgb(52, 164, 108)), to(rgb(5, 153, 144)));
  background: linear-gradient(90deg, rgb(139, 185, 41) 0%, rgb(52, 164, 108) 46%, rgb(5, 153, 144) 100%);
}
.sec_ttl.green::before {
  background: url(../img/point_bubble.svg) no-repeat center/cover;
}
.sec_ttl.orange {
  background: -webkit-gradient(linear, left top, right top, from(rgb(194, 21, 0)), color-stop(17%, rgb(203, 46, 0)), to(rgb(255, 197, 0)));
  background: linear-gradient(90deg, rgb(194, 21, 0) 0%, rgb(203, 46, 0) 17%, rgb(255, 197, 0) 100%);
}
.sec_ttl.orange::before {
  background: url(../img/point_bubble_orange.svg) no-repeat center/cover;
}
.sec_ttl .small {
  font-size: 80%;
}

/* ---------------------------------------
  .sec_bg
-----------------------------------------*/
.sec_bg_img {
  background: url(../img/bg_main.png) repeat-y top/100% auto;
}
@media screen and (max-width: 767px) {
  .sec_bg_img {
    background-image: url(../img/bg_main_sp.png);
  }
}

.sec_bg_check {
  background: url(../img/bg_check.png) repeat top;
}

.sec_bg_cream {
  background-color: #fffce4;
}

.sec_bg_gradation.green {
  background: -webkit-gradient(linear, left top, right top, from(rgb(139, 185, 41)), color-stop(46%, rgb(52, 164, 108)), to(rgb(5, 153, 144)));
  background: linear-gradient(90deg, rgb(139, 185, 41) 0%, rgb(52, 164, 108) 46%, rgb(5, 153, 144) 100%);
}
.sec_bg_gradation.orange {
  background: -webkit-gradient(linear, left top, right top, from(rgb(194, 21, 0)), color-stop(17%, rgb(203, 46, 0)), to(rgb(255, 197, 0)));
  background: linear-gradient(90deg, rgb(194, 21, 0) 0%, rgb(203, 46, 0) 17%, rgb(255, 197, 0) 100%);
}

/* ---------------------------------------
  #about
-----------------------------------------*/
#about {
  position: relative;
  padding-bottom: 44rem;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #about {
    padding-bottom: 0;
  }
}
#about::after {
  content: "";
  width: 184.5rem;
  aspect-ratio: 1847/581;
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: url(../img/img_sec01_01.png) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  #about::after {
    width: 102rem;
  }
}
#about .wrap {
  padding-top: 8.6rem;
}
@media screen and (max-width: 767px) {
  #about .wrap {
    padding-bottom: 25rem;
  }
}
#about .lead {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6666666667;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #about .lead {
    font-size: 2rem;
    line-height: 1.6;
  }
}
#about .lead .line {
  font-size: 150%;
  color: #ff5b00;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
  background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
}
#about .lead + .lead {
  margin-top: 1.5em;
}

/* ---------------------------------------
  #worry
-----------------------------------------*/
#worry {
  margin-top: -21.4rem;
  padding-top: 20rem;
}
@media screen and (max-width: 767px) {
  #worry {
    margin-top: -15.4rem;
  }
}
#worry .bg_white {
  background-color: #fff;
  padding: 4.3rem 0 5.8rem 4.9rem;
  position: relative;
  -webkit-box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 767px) {
  #worry .bg_white {
    padding: 4.3rem 2.4rem 5.8rem 2.4rem;
  }
}
#worry .bg_white::after {
  content: "";
  width: 38.7rem;
  height: 55.2rem;
  background: url(../img/img_worry_01.png) no-repeat center/cover;
  position: absolute;
  right: 0;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  #worry .bg_white::after {
    display: none;
  }
}
#worry .ttl_box .pop {
  font-size: 3.3rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #fff;
  padding: 1.4rem 1.2rem;
  background: -webkit-gradient(linear, left top, right top, from(rgb(194, 21, 0)), color-stop(17%, rgb(203, 46, 0)), to(rgb(255, 197, 0)));
  background: linear-gradient(90deg, rgb(194, 21, 0) 0%, rgb(203, 46, 0) 17%, rgb(255, 197, 0) 100%);
  position: absolute;
  top: -4.1rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  border-radius: 0.8rem;
}
#worry .ttl_box .pop::before {
  content: "";
  width: 1.6rem;
  height: 1.4rem;
  background: url(../img/point_bubble_orange.svg) no-repeat center/cover;
  position: absolute;
  left: 50%;
  bottom: -1.2rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#worry .ttl_box .ttl {
  font-size: 4.9rem;
  font-weight: 700;
  color: #cb2e00;
  line-height: 1.2653061224;
  text-align: center;
}
#worry .ttl_box .ttl .f_small {
  font-size: 80%;
}
#worry .list {
  margin-top: 4.8rem;
}
#worry .list li {
  font-size: 1.8rem;
  font-weight: 700;
  padding-left: 5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  #worry .list li {
    font-size: 2.4rem;
    line-height: 1.3333333333;
  }
}
#worry .list li::before {
  content: "";
  width: 3.5rem;
  aspect-ratio: 1/1;
  background: url(../img/point_check.svg) no-repeat center/contain;
  margin-right: 2.1rem;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  #worry .list li::before {
    top: 0.6rem;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
#worry .list li .f_large {
  font-size: 130%;
}
#worry .list li .line {
  font-size: 130%;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
  background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
}
#worry .list li .line .f_small {
  font-size: 100%;
}
#worry .list li + li {
  margin-top: 5rem;
}
#worry .solution_box {
  margin-top: -2.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 1.3rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  #worry .solution_box {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
#worry .solution_box .img_box {
  margin-left: 0.7rem;
  width: 27rem;
}
#worry .solution_box .txt_box {
  margin-top: 10.7rem;
}
@media screen and (max-width: 767px) {
  #worry .solution_box .txt_box {
    margin-top: 0;
    padding-bottom: 2rem;
  }
}
#worry .solution_box .txt_box .txt_ttl {
  font-size: 4rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
  line-height: 1.625;
}
#worry .solution_box .txt_box .txt_ttl .f_bg {
  background-color: #cb2e00;
}
#worry .solution_box .txt_box .txt_ttl .f_small {
  font-size: 80%;
}
#worry .solution_box .txt_box .txt_ttl .c_yellow {
  color: #ffec00;
}
#worry .solution_box .txt_box .txt_caption {
  font-size: 3rem;
  font-weight: 700;
  margin-top: 2rem;
  line-height: 1.3333333333;
}

/* ---------------------------------------
  #solution
-----------------------------------------*/
#solution {
  padding-bottom: 10rem;
}
#solution .lead_box {
  margin-top: 8.7rem;
}
#solution .lead_box .lead {
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #solution .lead_box .lead {
    font-size: 2.4rem;
    line-height: 1.25;
  }
}
#solution .lead_box .lead_point {
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  padding: 0.4rem 0 0.7rem 1.5rem;
  background-color: #ff5b00;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 1.5rem auto 0;
}
#solution .lead_box .lead_point + .lead {
  margin-top: 0.7rem;
}
#solution .list_box {
  background-color: #fff;
  -webkit-box-shadow: 5px 5px 7px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 5px 5px 7px 0px rgba(0, 0, 0, 0.08);
  padding: 4.7rem;
  position: relative;
  margin-top: 4.7rem;
}
#solution .list_box .list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2.5rem;
  font-size: 2.2rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  #solution .list_box .list li {
    font-size: 2.6rem;
  }
}
#solution .list_box .list li.f_large {
  font-size: 2.4rem;
  line-height: 1.4166666667;
}
@media screen and (max-width: 767px) {
  #solution .list_box .list li.f_large {
    font-size: 2.8rem;
    line-height: 1.3571428571;
  }
}
#solution .list_box .list li::before {
  content: "";
  width: 4.9rem;
  height: 4.9rem;
  background: url(../img/point_circle.svg) no-repeat center/contain;
  display: block;
}
#solution .list_box .list li + li {
  margin-top: 3rem;
}
#solution .list_box .img_box {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 39rem;
}
@media screen and (max-width: 767px) {
  #solution .list_box .img_box {
    position: relative;
    margin: 0 0 0 15rem;
  }
}
#solution .list_box .img_box .point_01,
#solution .list_box .img_box .point_02 {
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.4705882353;
  color: #cb2e00;
  position: absolute;
}
@media screen and (max-width: 767px) {
  #solution .list_box .img_box .point_01,
  #solution .list_box .img_box .point_02 {
    font-size: 2.2rem;
  }
}
#solution .list_box .img_box .point_01 {
  width: 20.3rem;
  height: 12.7rem;
  background: url(../img/pop_solution_01.svg) no-repeat center/contain;
  padding-left: 2.3rem;
  padding-top: 1.5rem;
  left: -5.1rem;
  top: 7.4rem;
}
@media screen and (max-width: 767px) {
  #solution .list_box .img_box .point_01 {
    width: 26.3rem;
    height: 16.4rem;
    left: -13.1rem;
    top: 3.4rem;
  }
}
#solution .list_box .img_box .point_02 {
  width: 22.5rem;
  height: 12.9rem;
  background: url(../img/pop_solution_02.svg) no-repeat center/contain;
  padding-left: 2.4rem;
  padding-top: 4rem;
  left: -13.5rem;
  bottom: 3.2rem;
}
@media screen and (max-width: 767px) {
  #solution .list_box .img_box .point_02 {
    width: 28.5rem;
    height: 16.4rem;
    left: -17.5rem;
    bottom: -1.8rem;
    padding-left: 3rem;
    padding-top: 4.5rem;
  }
}
#solution .end_txt {
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1.6666666667;
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  #solution .end_txt {
    font-size: 3.3rem;
    line-height: 1.6060606061;
  }
}
#solution .end_txt .t_bg {
  background-color: #cb2e00;
  padding-left: 1.5rem;
}
@media screen and (max-width: 767px) {
  #solution .end_txt .t_bg .sp_left {
    padding-left: 1.5rem;
  }
}

/* ---------------------------------------
  #price
-----------------------------------------*/
#price {
  padding: 9.7rem 0 10.1rem;
}
#price .ttl {
  font-size: 5rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
#price .bg_white {
  background-color: #fff;
  padding: 5rem;
  margin-top: 6rem;
}
#price .price_box {
  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;
  gap: 0 2.1rem;
}
#price .price_box .point {
  width: 11.4rem;
  height: 11.4rem;
  border-radius: 5.7rem;
  font-size: 2.8rem;
  font-weight: 700;
  color: #ff5b00;
  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-color: #ffec00;
}
#price .price_box .price {
  font-size: 11.3rem;
  font-weight: 700;
  color: #ff5b00;
}
#price .price_caption {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 1.9rem auto 0;
  padding: 1rem 2rem;
  background-color: #ff5b00;
  color: #fff;
  font-size: 2.6rem;
  font-weight: 700;
}
#price .price_caption .f_small {
  font-size: 80%;
}
#price .price_caption .f_yellow {
  color: #ffec00;
}
#price .price_att {
  font-size: 1.4rem;
  text-align: center;
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  #price .price_att {
    font-size: 2rem;
  }
}
#price .merit_box {
  background-color: #efefef;
  padding: 5rem;
  margin-top: 5rem;
}
#price .ttl_merit {
  font-size: 3.5rem;
  font-weight: 700;
  color: #cb2e00;
  text-align: center;
}
#price .list_merit {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 3rem 1fr 3rem 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 5rem 3rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #price .list_merit {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
#price .list_merit li .img_merit {
  width: 13.7rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #price .list_merit li .img_merit {
    width: 20rem;
  }
}
#price .list_merit li .list_ttl_merit {
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  margin-top: 1.4rem;
}
@media screen and (max-width: 767px) {
  #price .list_merit li .list_ttl_merit {
    font-size: 3rem;
  }
}
#price .list_merit li .txt_merit {
  font-size: 1.6rem;
  line-height: 1.625;
  padding-top: 1.5rem;
  margin-top: 1.2rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  #price .list_merit li .txt_merit {
    font-size: 2rem;
  }
}
#price .list_merit li .txt_merit::before {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 1.5px;
  background-color: #cb2e00;
  position: absolute;
  top: 0;
  left: 0;
}

/* ---------------------------------------
  #point
-----------------------------------------*/
#point {
  padding: 10rem 0;
}
#point .ttl_box::after {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 1.5px;
  background-color: #cb2e00;
  display: block;
}
#point .txt_point {
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  width: 9.6rem;
  height: 4.9rem;
  background: url(../img/bg_point.svg) no-repeat center/contain;
  padding: 0.9rem 0 0 1.1rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #point .txt_point {
    width: 12rem;
    height: 6.2rem;
    font-size: 3.1rem;
  }
}
#point .ttl {
  font-size: 5rem;
  font-weight: 700;
  text-align: center;
  margin-top: 0.7rem;
  padding-bottom: 1.8rem;
}
@media screen and (max-width: 767px) {
  #point .ttl {
    line-height: 1.2;
  }
}
#point .list_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 6.2rem;
}
@media screen and (max-width: 767px) {
  #point .list_box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2rem 0;
  }
}
#point .list_box .clm {
  width: 49rem;
  -webkit-box-shadow: 7px 7px 10px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 7px 7px 10px 0px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 767px) {
  #point .list_box .clm {
    width: 100%;
  }
}
#point .list_box .clm .clm_ttl {
  font-size: 2.6rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  padding: 1.5rem 0 1.7rem 0;
}
@media screen and (max-width: 767px) {
  #point .list_box .clm .clm_ttl {
    font-size: 3rem;
    padding: 2.5rem 0 2.8rem 0;
  }
}
#point .list_box .clm .inner {
  background-color: #fff;
  padding: 3rem;
}
#point .list_box .clm .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem 0;
}
#point .list_box .clm .list dt, #point .list_box .clm .list dd {
  font-size: 1.8rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  #point .list_box .clm .list dt, #point .list_box .clm .list dd {
    font-size: 2.4rem;
  }
}
#point .list_box .clm .txt {
  margin-top: 2.7rem;
  font-size: 1.8rem;
  line-height: 1.5555555556;
}
@media screen and (max-width: 767px) {
  #point .list_box .clm .txt {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#point .list_box .clm.orange .clm_ttl {
  background-color: #ff5b00;
}
#point .list_box .clm.orange .clm_ttl span {
  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;
  gap: 0 1.9rem;
}
#point .list_box .clm.orange .clm_ttl span::before {
  content: "";
  width: 3.3rem;
  height: 3.3rem;
  background: url(../img/point_circle_02.svg) no-repeat center/contain;
  display: block;
}
#point .list_box .clm.orange .list dt {
  width: calc(100% - 12rem);
}
@media screen and (max-width: 767px) {
  #point .list_box .clm.orange .list dt {
    width: calc(100% - 18rem);
  }
}
#point .list_box .clm.orange .list dd {
  width: 12rem;
  color: #ff5b00;
}
@media screen and (max-width: 767px) {
  #point .list_box .clm.orange .list dd {
    width: 18rem;
  }
}
#point .list_box .clm.orange .txt .f_green {
  color: #009a5c;
  font-weight: 700;
}
#point .list_box .clm.blue .clm_ttl {
  background-color: #0d64ac;
}
#point .list_box .clm.blue .clm_ttl span {
  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;
  gap: 0 1.9rem;
}
#point .list_box .clm.blue .clm_ttl span::before {
  content: "";
  width: 3.2rem;
  height: 3.2rem;
  background: url(../img/point_cross.svg) no-repeat center/contain;
  display: block;
}
#point .list_box .clm.blue .list dt {
  width: calc(100% - 13rem);
}
@media screen and (max-width: 767px) {
  #point .list_box .clm.blue .list dt {
    width: calc(100% - 18rem);
  }
}
#point .list_box .clm.blue .list dd {
  width: 13rem;
  color: #777;
}
@media screen and (max-width: 767px) {
  #point .list_box .clm.blue .list dd {
    width: 18rem;
  }
}
#point .list_box .clm.blue .txt .f_blue {
  color: #0d64ac;
  font-weight: 700;
}
#point .discription {
  font-size: 1.8rem;
  line-height: 1.8888888889;
  margin-top: 3.8rem;
}
@media screen and (max-width: 767px) {
  #point .discription {
    font-size: 2.4rem;
    line-height: 1.875;
  }
}
#point .discription .f_line {
  font-size: 130%;
  color: #ff5b00;
  font-weight: 700;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
  background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
}

/* ---------------------------------------
  #example
-----------------------------------------*/
#example {
  padding: 10rem 0;
}
#example .ttl {
  text-align: center;
  font-size: 5rem;
  font-weight: 700;
  color: #cb2e00;
}
#example .example_box {
  margin-top: 6rem;
}
#example .example_box .example_ttl {
  background-color: #cb2e00;
  padding: 1.5rem;
  color: #fff;
  text-align: center;
  font-size: 3.5rem;
  font-weight: 700;
}
#example .example_box .inner_white {
  background-color: #fff;
  padding: 4.3rem 5rem 5.1rem;
  -webkit-box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
}
#example .example_box .list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1.9rem 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.9rem;
}
@media screen and (max-width: 767px) {
  #example .example_box .list {
    -ms-grid-columns: (1fr)[1];
    grid-template-columns: repeat(1, 1fr);
  }
}
#example .example_box .list li {
  border: solid 3px #0069b9;
  border-radius: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#example .example_box .list li .number_box {
  width: 12.4rem;
  background-color: #0069b9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 2.3rem;
  font-weight: 700;
  color: #fff;
  padding: 2.3rem 0;
}
@media screen and (max-width: 767px) {
  #example .example_box .list li .number_box {
    font-size: 2.6rem;
    padding: 3.5rem 0;
  }
}
#example .example_box .list li .number_box .number {
  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;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 1.6rem;
  background-color: #fff;
  font-size: 1.9rem;
  color: #0069b9;
  margin-left: 0.8rem;
}
@media screen and (max-width: 767px) {
  #example .example_box .list li .number_box .number {
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 1.8rem;
    font-size: 2.3rem;
  }
}
#example .example_box .list li .txt_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5555555556;
  padding-left: 2.4rem;
}
@media screen and (max-width: 767px) {
  #example .example_box .list li .txt_box {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#example .example_box .img_box {
  margin-top: 3.7rem;
}
#example .example_box .img_att {
  font-size: 1.4rem;
  margin-top: -1.8rem;
}
@media screen and (max-width: 767px) {
  #example .example_box .img_att {
    margin-top: 0;
    font-size: 1.8rem;
  }
}
#example .end_txt01 {
  margin-top: 6rem;
  text-align: center;
  font-size: 4rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  #example .end_txt01 {
    font-size: 3.5rem;
  }
}
#example .end_txt01 .f_bg {
  background-color: #cb2e00;
  padding-left: 1.1rem;
}
#example .end_txt02 {
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.4166666667;
  margin-top: 2.5rem;
}

/* ---------------------------------------
  #case
-----------------------------------------*/
#case {
  padding: 10rem 0;
}
#case .ttl {
  font-size: 5rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
#case .case_list {
  margin-top: 5.8rem;
}
#case .clm_case {
  background-color: #fff;
  padding: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 2.8rem;
}
@media screen and (max-width: 767px) {
  #case .clm_case {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}
#case .clm_case .img_box {
  width: 26.2rem;
  -webkit-box-flex: 0;
      -ms-flex: none;
          flex: none;
}
@media screen and (max-width: 767px) {
  #case .clm_case .img_box {
    margin: 0 auto;
  }
}
#case .clm_case .txt_box .case_name {
  padding-left: 1rem;
  font-size: 1.8rem;
  font-weight: 700;
  color: #9e9e9e;
}
@media screen and (max-width: 767px) {
  #case .clm_case .txt_box .case_name {
    text-align: center;
    margin-top: 1rem;
    font-size: 2.4rem;
    padding-left: 0;
  }
}
#case .clm_case .txt_box .case_ttl {
  margin-top: 1.4rem;
  padding-left: 1rem;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4166666667;
}
@media screen and (max-width: 767px) {
  #case .clm_case .txt_box .case_ttl {
    margin-top: 3rem;
    font-size: 3rem;
  }
}
#case .clm_case .txt_box .case_txt {
  padding-top: 1.7rem;
  padding-left: 1rem;
  font-size: 1.6rem;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  #case .clm_case .txt_box .case_txt {
    font-size: 2.4rem;
  }
}
#case .clm_case .txt_box .case_txt::before {
  content: "";
  width: calc(100% + 1rem);
  height: 3px;
  background-color: #cb2e00;
  border-radius: 1.5px;
  margin-bottom: 2.8rem;
  margin-left: -1rem;
  display: block;
}
#case .clm_case + .clm_case {
  margin-top: 2.8rem;
}

/* ---------------------------------------
  #item
-----------------------------------------*/
#item {
  padding: 10rem 0;
}
#item .ttl {
  font-size: 5rem;
  font-weight: 700;
  padding: 0.5rem 2.5rem 1rem;
  background-color: #ff5b00;
  color: #fff;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
#item .lead {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 700;
  margin-top: 6rem;
  line-height: 1.5555555556;
}
@media screen and (max-width: 767px) {
  #item .lead {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#item .bg_white {
  background-color: #fff;
  -webkit-box-shadow: 5px 5px 8px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 5px 5px 8px 0px rgba(0, 0, 0, 0.08);
  margin-top: 6.3rem;
  padding: 5rem;
}
#item .catch_box {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
#item .catch_box::before, #item .catch_box::after {
  content: "";
  width: 9.6rem;
  height: 5px;
  border-radius: 2.5px;
  background-color: #00a096;
  position: absolute;
}
@media screen and (max-width: 767px) {
  #item .catch_box::before, #item .catch_box::after {
    width: 12rem;
    height: 3px;
  }
}
#item .catch_box::before {
  left: -4.5rem;
  top: 1rem;
  -webkit-transform: rotate(60deg);
          transform: rotate(60deg);
  -webkit-transform-origin: left center;
          transform-origin: left center;
}
@media screen and (max-width: 767px) {
  #item .catch_box::before {
    top: 2rem;
    left: -6rem;
    -webkit-transform: rotate(65deg);
            transform: rotate(65deg);
  }
}
#item .catch_box::after {
  right: -4.5rem;
  top: 1rem;
  -webkit-transform: rotate(-60deg);
          transform: rotate(-60deg);
  -webkit-transform-origin: right center;
          transform-origin: right center;
}
@media screen and (max-width: 767px) {
  #item .catch_box::after {
    top: 2rem;
    right: -6rem;
    -webkit-transform: rotate(-65deg);
            transform: rotate(-65deg);
  }
}
#item .txt_catch {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #item .txt_catch {
    font-size: 3rem;
  }
}
#item .txt_catch .f_line {
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 236, 0)), color-stop(34%, rgb(255, 236, 0)), color-stop(34%, rgba(255, 236, 0, 0)));
  background: linear-gradient(0deg, rgb(255, 236, 0) 0%, rgb(255, 236, 0) 34%, rgba(255, 236, 0, 0) 34%);
  color: #ff5b00;
}
#item .txt_catch .f_l_180 {
  font-size: 180%;
}
#item .txt_catch .f_l_120 {
  font-size: 120%;
}
#item .txt_app {
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  #item .txt_app {
    font-size: 2.4rem;
  }
}
#item .list {
  margin-top: 4.5rem;
  display: -ms-grid;
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-grid-columns: 1fr 1.9rem 1fr 1.9rem 1fr 1.9rem 1fr 1.9rem 1fr 1.9rem 1fr;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.9rem;
}

/* ---------------------------------------
  #reason
-----------------------------------------*/
#reason {
  padding-bottom: 10rem;
}
#reason .bg_white {
  background-color: #fff;
  padding: 8rem 5rem 5rem;
  position: relative;
  -webkit-box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 6px 6px 9px 0px rgba(0, 0, 0, 0.08);
}
@media screen and (max-width: 767px) {
  #reason .bg_white {
    padding-top: 12rem;
  }
}
#reason .clm_ttl {
  padding: 1.2rem 2.5rem 2rem 2.7rem;
  border-radius: 1rem;
  color: #fff;
  font-size: 3.5rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
  position: absolute;
  top: -3.8rem;
}
@media screen and (max-width: 767px) {
  #reason .clm_ttl {
    text-align: center;
    line-height: 1.2857142857;
  }
}
#reason .clm_ttl .f_yellow {
  font-size: 120%;
  color: #ffec00;
}
#reason .clm_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #reason .clm_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 10rem 0;
  }
}
#reason .clm_list .clm_li {
  width: 42.2rem;
}
@media screen and (max-width: 767px) {
  #reason .clm_list .clm_li {
    width: 100%;
  }
}
#reason .clm_list .clm_li .img_txt {
  margin-top: 1.5rem;
}
#reason .clm_list .clm_li .img_txt li {
  font-size: 1.8rem;
  line-height: 1.6666666667;
}
@media screen and (max-width: 767px) {
  #reason .clm_list .clm_li .img_txt li {
    font-size: 2.6rem;
    line-height: 1.6153846154;
  }
}
#reason .clm_list .clm_li .img_txt.dot li {
  padding-left: 1em;
  text-indent: -1em;
}
#reason .clm_list .clm_li .img_txt.dot li::before {
  content: "・";
}
#reason .clm_list .clm_li .img_txt.icon li {
  font-weight: 700;
  padding-left: 3.4rem;
  position: relative;
}
#reason .clm_list .clm_li .img_txt.icon li::before {
  content: "";
  width: 2rem;
  height: 2rem;
  background: url(../img/point_circle.svg) no-repeat center/contain;
  position: absolute;
  left: 0;
  top: 0.8rem;
}
@media screen and (max-width: 767px) {
  #reason .clm_list .clm_li .img_txt.icon li::before {
    width: 2.4rem;
    height: 2.4rem;
    top: 1rem;
  }
}
@media screen and (min-width: 768px) {
  #reason .clm_list .clm_li:nth-of-type(1) .img {
    position: relative;
  }
  #reason .clm_list .clm_li:nth-of-type(1) .img::after {
    content: "";
    width: 2.7rem;
    height: 4.8rem;
    background: url(../img/icon_arrow_reason.svg) no-repeat center/contain;
    position: absolute;
    top: 50%;
    right: -4.2rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media screen and (max-width: 767px) {
  #reason .clm_list .clm_li:nth-of-type(1) {
    position: relative;
  }
  #reason .clm_list .clm_li:nth-of-type(1)::after {
    content: "";
    width: 2.7rem;
    height: 4.8rem;
    background: url(../img/icon_arrow_reason.svg) no-repeat center/contain;
    position: absolute;
    bottom: -6.5rem;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(90deg);
            transform: translateX(-50%) rotate(90deg);
  }
}
#reason .txt_underlist {
  margin-top: 4.8rem;
  text-align: center;
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.6666666667;
}
#reason .txt_underlist .f_bg {
  background-color: #00a096;
  padding-left: 1rem;
}
#reason .reason_clm {
  margin-top: 12.5rem;
}
#reason .reason_clm.clm01 .clm_ttl {
  background-color: #0069b9;
  left: 13.1rem;
}
@media screen and (max-width: 767px) {
  #reason .reason_clm.clm01 .clm_ttl {
    left: 11.5rem;
  }
}
#reason .reason_clm.clm02 .clm_ttl {
  background-color: #00a0eb;
  left: 11.1rem;
}
@media screen and (max-width: 767px) {
  #reason .reason_clm.clm02 .clm_ttl {
    left: 12rem;
  }
}

/* ---------------------------------------
  #support
-----------------------------------------*/
#support {
  padding: 10rem 0 7.5rem;
}
@media screen and (max-width: 767px) {
  #support {
    padding-bottom: 2.5rem;
  }
}
#support .ttl {
  font-size: 5rem;
  font-weight: 700;
  padding: 0.5rem 2.5rem 1rem;
  background-color: #ff5b00;
  color: #fff;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
#support .bg_white {
  background-color: #fff;
  -webkit-box-shadow: 8px 8px 5px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 8px 8px 5px 0px rgba(0, 0, 0, 0.08);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #support .bg_white {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
    margin-top: 10rem;
    padding: 5rem 3rem 2.5rem;
  }
}
#support .bg_white .img_box {
  width: 41.2rem;
  -webkit-box-flex: 0;
      -ms-flex: none;
          flex: none;
}
#support .bg_white .txt_box {
  padding: 0 3.7rem 0 5rem;
}
@media screen and (max-width: 767px) {
  #support .bg_white .txt_box {
    padding: 0;
  }
}
#support .bg_white .txt_box .support_ttl {
  font-size: 2.8rem;
  font-weight: 700;
  color: #fff;
  background-color: #0069b9;
  border-radius: 1rem;
  padding: 1.5rem 2.5rem;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  #support .bg_white .txt_box .support_ttl {
    position: absolute;
    top: -4rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    text-align: center;
    line-height: 1.3571428571;
    width: 80%;
  }
}
#support .bg_white .txt_box .support_ttl::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 7px solid transparent;
  border-left: 7px solid transparent;
  border-top: 7px solid #0069b9;
  border-bottom: 0;
  position: absolute;
  left: 50%;
  bottom: -6px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
#support .bg_white .txt_box .support_txt {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5555555556;
  margin-top: 3.5rem;
}
@media screen and (max-width: 767px) {
  #support .bg_white .txt_box .support_txt {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#support .bg_white .txt_box .support_txt .f_orange {
  color: #ff5b00;
}
#support .under_txt01 {
  margin-top: 6rem;
  text-align: center;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.7333333333;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #support .under_txt01 {
    font-size: 3.5rem;
  }
}
#support .under_txt01 .f_bg {
  background-color: #00a096;
  padding-left: 1rem;
}
@media screen and (max-width: 767px) {
  #support .under_txt01 .f_bg .sp_left {
    padding-left: 1rem;
  }
}
#support .under_txt01 .f_yellow {
  color: #ffec00;
  font-size: 120%;
}
#support .under_txt02 {
  font-size: 2.4rem;
  font-weight: 700;
  padding-left: 19.6rem;
  margin-top: 2.7rem;
}
@media screen and (max-width: 767px) {
  #support .under_txt02 {
    line-height: 1.4166666667;
    padding-left: 0;
    text-align: center;
    margin-top: 2rem;
  }
}

/* ---------------------------------------
  .contact_sec
-----------------------------------------*/
.contact_sec {
  background: -webkit-gradient(linear, left top, right top, from(rgb(139, 185, 41)), color-stop(46%, rgb(52, 164, 108)), to(rgb(5, 153, 144)));
  background: linear-gradient(90deg, rgb(139, 185, 41) 0%, rgb(52, 164, 108) 46%, rgb(5, 153, 144) 100%);
  padding: 2.3rem 0 2.1rem;
}
.contact_sec .wrap {
  position: relative;
}
.contact_sec .txt_pop {
  font-size: 3rem;
  font-weight: 700;
  color: #fff;
  margin-left: 31rem;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .contact_sec .txt_pop {
    margin-left: 18rem;
    text-align: center;
    font-size: 3.2rem;
    line-height: 1.3125;
  }
}
.contact_sec .txt_pop::before, .contact_sec .txt_pop::after {
  content: "";
  width: 3.2rem;
  height: 4px;
  border-radius: 2px;
  background-color: #fff;
  position: absolute;
  top: 0;
}
@media screen and (max-width: 767px) {
  .contact_sec .txt_pop::before, .contact_sec .txt_pop::after {
    width: 8rem;
    height: 3px;
    border-radius: 1.5px;
  }
}
.contact_sec .txt_pop::before {
  left: -4rem;
  -webkit-transform: rotate(60deg);
          transform: rotate(60deg);
  -webkit-transform-origin: left center;
          transform-origin: left center;
}
@media screen and (max-width: 767px) {
  .contact_sec .txt_pop::before {
    left: -5rem;
    -webkit-transform: rotate(65deg);
            transform: rotate(65deg);
  }
}
.contact_sec .txt_pop::after {
  right: -3rem;
  -webkit-transform: rotate(-60deg);
          transform: rotate(-60deg);
  -webkit-transform-origin: right center;
          transform-origin: right center;
}
@media screen and (max-width: 767px) {
  .contact_sec .txt_pop::after {
    -webkit-transform: rotate(-65deg);
            transform: rotate(-65deg);
    right: -4rem;
  }
}
.contact_sec .txt_pop .f_yellow {
  color: #ffec00;
}
.contact_sec .bg_white {
  background-color: #fff;
  border-radius: 1.6rem;
  margin-top: 2.1rem;
  padding: 2.7rem 0 3rem;
}
.contact_sec .contact_txt {
  margin-left: 28.7rem;
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_txt {
    margin-left: 24rem;
    line-height: 1.4166666667;
  }
}
.contact_sec .contact_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2.7rem;
  margin-left: 24rem;
  margin-top: 2.3rem;
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-right: 2rem;
    gap: 1.5rem 0;
  }
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_list .tel {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .contact_sec .contact_list .tel .tel_link {
    width: 38.2rem;
    height: 8.2rem;
    border-radius: 4.1rem;
    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;
    gap: 0 2rem;
    background-color: #00a096;
  }
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_list .tel .tel_link a {
    width: 100%;
    height: 7.8rem;
    border-radius: 3.9rem;
    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;
    gap: 0 1.4rem;
    background-color: #00a096;
  }
}
.contact_sec .contact_list .tel .icon {
  width: 4.1rem;
}
.contact_sec .contact_list .tel .tel_text {
  font-size: 3.7rem;
  font-weight: 900;
  color: #fff;
}
.contact_sec .contact_list .tel .time {
  font-size: 1.4rem;
  font-weight: 500;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_list .mail {
    width: 100%;
  }
}
.contact_sec .contact_list .mail a {
  width: 31.6rem;
  height: 8.2rem;
  border-radius: 4.1rem;
  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;
  gap: 0 2.3rem;
  background-color: #ff5b00;
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_list .mail a {
    width: 100%;
    height: 7.8rem;
  }
}
.contact_sec .contact_list .mail .icon {
  width: 3rem;
}
.contact_sec .contact_list .mail .txt {
  font-size: 2.7rem;
  font-weight: 700;
  color: #fff;
}
.contact_sec .contact_img {
  width: 27rem;
  position: absolute;
  bottom: 0;
  left: -1rem;
}
@media screen and (max-width: 767px) {
  .contact_sec .contact_img {
    width: 25rem;
  }
}

/* ---------------------------------------
  #flow
-----------------------------------------*/
#flow {
  padding: 10rem 0;
}
#flow .ttl {
  text-align: center;
  font-size: 5rem;
  font-weight: 700;
}
#flow .ttl::after {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 1.5px;
  background-color: #00a096;
  margin-top: 1.7rem;
  display: block;
}
#flow .lead {
  font-size: 1.8rem;
  text-align: center;
  margin-top: 3.1rem;
}
@media screen and (max-width: 767px) {
  #flow .lead {
    font-size: 3rem;
  }
}
#flow .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 6.6rem;
}
@media screen and (max-width: 767px) {
  #flow .list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 5rem 1fr 5rem 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem 5rem;
  }
}
#flow .list li {
  width: 16.6rem;
}
@media screen and (max-width: 767px) {
  #flow .list li {
    width: auto;
  }
}
#flow .list li .number {
  text-align: center;
  font-size: 3.8rem;
  font-weight: 700;
}
#flow .list li .list_img {
  margin-top: 0.8rem;
}
#flow .list li .list_ttl {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  margin-top: 2rem;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #flow .list li .list_ttl {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}
#flow .list li .list_txt {
  margin: 0.5rem auto 0;
  font-size: 1.6rem;
  line-height: 1.625;
  width: 14.4rem;
}
@media screen and (max-width: 767px) {
  #flow .list li .list_txt {
    width: 100%;
    font-size: 2rem;
    line-height: 1.5;
  }
}
#flow .list li:nth-of-type(n+2) .list_img {
  position: relative;
}
#flow .list li:nth-of-type(n+2) .list_img::before {
  content: "";
  width: 1.7rem;
  height: 2.8rem;
  background: url(../img/icon_flow_arrow.svg) no-repeat center/contain;
  position: absolute;
  left: -2.9rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  #flow .list li:nth-of-type(n+2) .list_img::before {
    left: -3.5rem;
  }
}
#flow .list li:nth-of-type(1) .number {
  color: #00a0eb;
}
#flow .list li:nth-of-type(2) .number {
  color: #0069b9;
}
#flow .list li:nth-of-type(3) .number {
  color: #91c31e;
}
#flow .list li:nth-of-type(4) .number {
  color: #00a096;
}
@media screen and (max-width: 767px) {
  #flow .list li:nth-of-type(4) .list_img::before {
    content: none;
  }
}
#flow .list li:nth-of-type(5) .number {
  color: #ff5b00;
}

/* ---------------------------------------
  #faq
-----------------------------------------*/
#faq {
  padding: 10rem 0;
}
#faq .ttl {
  font-size: 5rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
#faq .bg_white {
  margin-top: 6.4rem;
  background-color: #fff;
  -webkit-box-shadow: 8px 8px 12px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 8px 8px 12px 0px rgba(0, 0, 0, 0.08);
  padding: 5rem 5rem 5rem 4rem;
}
#faq .clm_faq .acordion_ttl {
  cursor: pointer;
  position: relative;
  z-index: 1;
  font-size: 2.4rem;
  font-weight: 700;
  padding-left: 6.5rem;
  padding-right: 7.2rem;
  line-height: 1.4166666667;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  #faq .clm_faq .acordion_ttl {
    font-size: 2.8rem;
    line-height: 1.3571428571;
  }
}
#faq .clm_faq .acordion_ttl::before {
  content: "Q";
  width: 4rem;
  height: 4rem;
  border-radius: 2rem;
  background-color: #0069b9;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-right: 2.3rem;
  padding-top: 0.5rem;
  line-height: 1;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  #faq .clm_faq .acordion_ttl::before {
    width: 4.6rem;
    height: 4.6rem;
    border-radius: 2.3rem;
  }
}
#faq .clm_faq .acordion_ttl .icon {
  width: 3rem;
  height: 3rem;
  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;
  position: absolute;
  right: 1.1rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
#faq .clm_faq .acordion_ttl .icon::before, #faq .clm_faq .acordion_ttl .icon::after {
  content: "";
  width: 0.4rem;
  height: 3rem;
  background-color: #0069b9;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
#faq .clm_faq .acordion_ttl .icon::before {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}
#faq .clm_faq .acordion_ttl.active .icon::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (any-hover: hover) {
  #faq .clm_faq .acordion_ttl:hover {
    opacity: 0.7;
  }
}
#faq .clm_faq .acordion_detail {
  display: none;
  margin-top: 2.8rem;
  padding-top: 2.2rem;
  position: relative;
  padding-left: 6.5rem;
  font-size: 1.6rem;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  #faq .clm_faq .acordion_detail {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#faq .clm_faq .acordion_detail::before {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 1.5px;
  background-color: #e8e8e8;
  position: absolute;
  top: 0;
  left: 0;
}
#faq .clm_faq .acordion_detail.active {
  display: block;
}
#faq .clm_faq + .clm_faq {
  margin-top: 5.5rem;
}

/* ---------------------------------------
  #consider
-----------------------------------------*/
#consider {
  padding: 10rem 0 8.7rem;
}
#consider .ttl {
  padding-bottom: 2rem;
  position: relative;
  font-size: 4rem;
  font-weight: 700;
  color: #0069b9;
  text-align: center;
}
#consider .ttl::after {
  content: "";
  width: 100%;
  height: 3px;
  border-radius: 1.5px;
  background-color: #0069b9;
  position: absolute;
  bottom: 0;
  left: 0;
}
#consider .txt {
  font-size: 1.8rem;
  line-height: 1.5555555556;
  text-align: center;
  margin-top: 3.6rem;
}
@media screen and (max-width: 767px) {
  #consider .txt {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}

/* ---------------------------------------
  #company
-----------------------------------------*/
#company {
  padding: 10rem 0;
  background-color: #efefef;
}
#company .ttl {
  font-size: 5rem;
  font-weight: 700;
  color: #00a096;
  text-align: center;
}
#company .bg_white {
  background-color: #fff;
  -webkit-box-shadow: 7px 7px 10px 0px rgba(0, 0, 0, 0.08);
          box-shadow: 7px 7px 10px 0px rgba(0, 0, 0, 0.08);
  margin-top: 6rem;
  padding: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  #company .bg_white {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#company .bg_white .txt_box {
  width: 38.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3rem 0;
}
@media screen and (max-width: 767px) {
  #company .bg_white .txt_box {
    width: 100%;
  }
}
#company .bg_white .txt_box dt, #company .bg_white .txt_box dd {
  font-size: 1.6rem;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  #company .bg_white .txt_box dt, #company .bg_white .txt_box dd {
    font-size: 2.4rem;
    line-height: 1.4166666667;
  }
}
#company .bg_white .txt_box dt {
  font-weight: 700;
  color: #00a096;
  width: 11.4rem;
}
@media screen and (max-width: 767px) {
  #company .bg_white .txt_box dt {
    width: 18rem;
  }
}
#company .bg_white .txt_box dd {
  width: calc(100% - 11.4rem);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (max-width: 767px) {
  #company .bg_white .txt_box dd {
    width: calc(100% - 18rem);
  }
}
#company .bg_white .img_box {
  width: 44.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  #company .bg_white .img_box {
    width: 100%;
    margin-top: 2.5rem;
  }
}
#company .bg_white .img_box li {
  width: 47%;
}
#company .bg_white .img_box li:nth-of-type(1) {
  width: 100%;
  margin-bottom: 2.3rem;
}

/* ---------------------------------------
  表示・非表示処理
-----------------------------------------*/
.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}