@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Color+Emoji&display=swap");

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
  font: inherit;
}

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

input,
select,
textarea {
  background-color: transparent;
  outline: none;
}

button {
  cursor: pointer;
  background-color: transparent;
  outline: none;
  border: 0;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

div,
p {
  word-break: break-all;
}

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,
nav,
picture {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

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

table {
  border-spacing: inherit;
  border-collapse: collapse;
}

figure {
  margin: 0;
  padding: 0;
  line-height: 0;
}

input[type="submit"] {
  border: none;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  margin: 0;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic,
    "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo,
    sans-serif;
  scroll-padding-top: 8rem;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

@media screen and (max-width: 750px) {
  html {
    scroll-padding-top: 11rem;
  }
}

@media (min-width: 751px) and (max-width: 1645px) {
  html {
    font-size: 0.6079027356vw;
  }
}

@media (max-width: 750px) {
  html {
    font-size: 1.3333333333vw;
  }
}

@media screen and (min-width: 751px) {
  .onlySP {
    display: none !important;
  }
}

@media screen and (max-width: 750px) {
  .onlyPC {
    display: none !important;
  }
}

body {
  font-family: "noto-sans-cjk-jp", sans-serif;
  color: #000;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.8;
  overflow-wrap: break-word;
  overflow-x: hidden;
  width: 100%;
}

@media screen and (max-width: 750px) {
  body.overflow {
    overflow: hidden;
  }
}

a {
  color: inherit;
  text-decoration: none;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}

a:focus {
  outline: none;
  text-decoration: none;
}

p {
  margin: 0px;
  padding: 0;
  font-size: 1.6rem;
}

p:last-child {
  margin-bottom: 0px;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

span {
  display: inline-block;
}

/* clearfix (micro) */
.clearfix:before,
.clearfix:after {
  content: " ";
  display: table;
}

.clearfix:after {
  clear: both;
}

@media screen and (min-width: 751px) {
  a[href^="tel"] {
    pointer-events: none;
    text-decoration: none;
    opacity: 1 !important;
    cursor: default !important;
  }
}

.m-auto {
  margin: 0 auto;
}

.taC {
  text-align: center;
}

.taR {
  text-align: right;
}

.c-white {
  color: #fff;
}

.fw-bold {
  font-weight: bold;
}

.txt_green {
  display: inline;
  color: #1b9131;
}

.txt_blue {
  color: #0d71d7;
}

.yellow_line {
  display: inline;
  background: rgba(0, 0, 0, 0) -webkit-gradient(
      linear,
      left top,
      left bottom,
      color-stop(77%, transparent),
      color-stop(0%, #fff2a5)
    ) repeat scroll 0 -0.375rem;
  background: rgba(0, 0, 0, 0) linear-gradient(transparent 77%, #fff2a5 0%)
    repeat scroll 0 -0.375rem;
}

.m00 {
  margin: 0 !important;
}

.fit {
  font-family: "object-fit: cover;";
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.c-poR {
  position: relative;
}

.c-poA {
  position: absolute;
}

.c-fixed {
  position: fixed;
}

.c-txt {
  font-size: 1.6rem;
  line-height: 1.625;
  color: #000;
  font-weight: 400;
  text-align: justify;
}

@media screen and (max-width: 750px) {
  .c-txt {
    font-size: 2.8rem;
    line-height: 1.7857142857;
  }
}

.c-container {
  max-width: 114rem;
  width: 100%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 750px) {
  .c-container {
    padding: 0 3rem;
  }
}

#wrapper {
  background-color: #fffefb;
  position: relative;
  width: 100%;
  overflow: hidden;
}

#thanks .header {
  position: relative;
}
header .logo > a {
  padding: 2rem;
  display: block;
}
header .logo > a img {
  margin: 0;
  max-width: 25rem;
}
header .title {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 35px;
  font-weight: bold;
  height: 170px;
  background: linear-gradient(
    90deg,
    rgb(27, 145, 49) 0%,
    rgb(96 251 125) 50%,
    rgb(27, 145, 49) 100%
  );
}

.wrapper_inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
}

.thanks_inner {
  flex: 1 auto;
  background-color: #f8f8f8;
}

.thanks_content {
  margin: 80px auto;
  max-width: 100%;
  padding: 0 40px;
  width: 100%;
  text-align: center;
}
.thanks_content p {
  line-height: 2;
  font-size: 2rem;
  font-weight: bold;
}


.top_back {
  text-align: center;
}

.top_back > a {
  text-decoration: none;
  font-size: 2.5rem;
  font-weight: bold;
  background-color: rgb(27, 145, 49);
  color: #fff;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  max-width: 300px;
  width: 100%;
  height: 70px;
  box-sizing: border-box;
  cursor: pointer;
  line-height: 1.5;
  padding: 10px 30px;
  transition: 0.3s ease;
  border: 0.2rem solid rgb(27, 145, 49);
}
@media screen and (min-width: 751px) {
  .top_back > a:hover {
    background-color: #fff;
    color: #000;
    opacity: 1;
  }
}

@media screen and (max-width: 750px) {
  header .title {
    font-size: 30px;
    height: 150px;
  }

  .thanks_content {
    margin: 40px auto 50px;
    padding: 0 20px;
    box-sizing: border-box;
  }

  .thanks_content p {
    font-size: 16px;
    text-align: justify;
  }
}

.footer-logo {
  padding: 2.5rem 0;
  text-align: center;
}

.footer-logo > a {
  display: block;
  width: 16.3rem;
  margin: 0 auto;
}

@media screen and (max-width: 750px) {
  .footer-logo {
    padding: 3.5rem 0;
  }

  .footer-logo > a {
    width: 19.8rem;
  }
}

.footer-copyright {
  background-color: #f8f8f8;
  padding: 2.5rem 0;
}

.footer-copyright p {
  text-align: center;
  color: #b8b8b8;
  font-size: 2rem;
  font-weight: bold;
}

.header {
  position: fixed;
  width: 100%;
  left: 0;
  top: 0;
  z-index: 99;
  border-bottom: 1px solid #fff;
  background-color: rgba(27, 145, 49, 0.9);
}

.header-inner {
  min-height: 11rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 2rem;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.header-left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3rem;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.header-left--logo {
  width: 18.5rem;
}

.header-left--txt {
  font-size: 2.4rem;
  line-height: 1.5;
  color: #fff;
}

.header-btn {
  min-width: 30rem;
  min-height: 5.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.8rem;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 2.7rem;
  background-color: rgb(255, 219, 0);
  -webkit-box-shadow: 0px 0.4rem 0px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 0.4rem 0px 0px rgba(0, 0, 0, 0.2);
}

.header-btn--text {
  font-size: 2.8rem;
  font-weight: bold;
  color: #2e2e2e;
  line-height: 1.2;
}

.header-btn--icon {
  width: 5rem;
  height: 1.9rem;
  position: relative;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

.header-btn--icon::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  width: 100%;
  height: 100%;
  background-image: url(../img/arrow_btn.png);
  left: 0;
  top: 0;
  z-index: 1;
}

.header-btn:hover .header-btn--icon {
  -webkit-transform: translateX(1rem);
  transform: translateX(1rem);
}

@media screen and (max-width: 750px) {
  .header-inner {
    min-height: 14.3rem;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .header-left {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
  }

  .header-left--logo {
    width: 25.1rem;
  }

  .header-left--txt {
    font-size: 3rem;
    text-align: right;
  }
}

#main-top{
  background-color: #fff;
}

#main-top .main-top__inner {
  z-index: 2;
  position: relative;
  /* background-color: #fff; */
}

#main-top .concerns::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-color: #fff;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  border-radius: 34rem 0 0 0;
  z-index: -1;
}

@media screen and (max-width: 750px) {
  #main-top .concerns::before {
    border-radius: 13.5rem 0 0 0;
  }
}

#main-top .fv {
  position: relative;
  padding-top: 11rem;
}

#main-top .fv .fv-fadeIn {
  -webkit-transform: translateY(2rem);
  transform: translateY(2rem);
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out,
    -webkit-transform 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out, -webkit-transform 0.5s ease-in-out;
  transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
  transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out,
    -webkit-transform 0.5s ease-in-out;
}

#main-top .fv .fv-fadeIn.active {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

#main-top .fv .fv-fadeIn.active.delay01 {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

#main-top .fv .fv-fadeIn.active.delay02 {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}

#main-top .fv .fv-fadeIn.active.delay03 {
  -webkit-transition-delay: 0.9s;
  transition-delay: 0.9s;
}

#main-top .fv .fv-fadeIn.active.delay04 {
  -webkit-transition-delay: 1.2s;
  transition-delay: 1.2s;
}

#main-top .fv .fv-fadeIn.active.delay05 {
  -webkit-transition-delay: 1.5s;
  transition-delay: 1.5s;
}

#main-top .fv-bg {
  position: absolute;
  width: 100%;
  height: auto;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 0;
  min-width: 192rem;
}

#main-top .fv-bg img {
  width: 100%;
}

#main-top .fv-bgGreen {
  position: absolute;
  width: 100%;
  height: 48.3rem;
  top: 11rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: rgb(27, 145, 49);
  opacity: 0.9;
  border-radius: 0 0 37rem 0;
  z-index: 1;
}

#main-top .fv-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  height: 69rem;
}

#main-top .fv-inner__content {
  width: calc(100% - 53.5rem);
  padding-top: 4.2rem;
}

#main-top .fv-inner__content-title--sub > span {
  font-size: 3.3rem;
  font-weight: 500;
  color: #1b9131;
  border-radius: 0 0 30rem 0;
  line-height: 1.2;
  background-color: #fff;
  padding: 1rem 4rem 1rem 2rem;
  letter-spacing: 0.07em;
}

#main-top .fv-inner__content-title--main {
  margin-top: 1.6rem;
  font-size: 4.8rem;
  font-weight: bold;
  line-height: 1.45;
  letter-spacing: 0.05em;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

#main-top .fv-inner__content-title--main .larg {
  color: #ffe84f;
  font-size: 8.8rem;
  line-height: 1.3;
  margin-left: -1rem;
}

#main-top .fv-inner__content-title--main .num {
  font-family: din-2014, sans-serif;
  font-size: 14rem;
  position: relative;
  top: 0.5rem;
  line-height: 0.8;
  font-weight: 600;
}

#main-top .fv-inner__content-title--main .small {
  font-size: 6.5rem;
}

#main-top .fv-inner__content-title--main .end {
  letter-spacing: 0px;
}

#main-top .fv-inner__content-title--main .label {
  font-size: 3rem;
  line-height: 1.4;
  border: 0.2rem solid #fff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0rem 0.7rem;
  margin-left: 2.3rem;
  position: relative;
  top: -0.5rem;
}

#main-top .fv-inner__content-btn {
  margin-top: 9rem;
}

#main-top .fv-inner__content-btn--link {
  width: 57rem;
  min-height: 8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3rem;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 4rem;
  background-color: rgb(255, 219, 0);
  -webkit-box-shadow: 0px 0.6rem 0px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 0.6rem 0px 0px rgba(0, 0, 0, 0.2);
}

@media screen and (min-width: 751px) {
  #main-top .fv-inner__content-btn--link:hover .fv-inner__content-btn--icon {
    -webkit-transform: translateX(1rem);
    transform: translateX(1rem);
  }
}

#main-top .fv-inner__content-btn--text {
  font-size: 4rem;
  font-weight: bold;
  color: #2e2e2e;
  line-height: 1.2;
}

#main-top .fv-inner__content-btn--icon {
  width: 5rem;
  height: 1.9rem;
  position: relative;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}

#main-top .fv-inner__content-btn--icon::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  width: 100%;
  height: 100%;
  background-image: url(../img/arrow_btn.png);
  left: 0;
  top: 0;
  z-index: 1;
}

#main-top .fv-inner__pic {
  width: 53.5rem;
  position: relative;
}

#main-top .fv-inner__pic--item {
  width: 71.1rem;
  margin-left: 3.4rem;
  margin-top: 2rem;
}

#main-top .fv-inner__pic--circle {
  position: absolute;
  left: 0.2rem;
  top: 18rem;
  z-index: -1;
  width: 20.8rem;
  height: 20.8rem;
  background-color: #fff;
  border-radius: 50%;
  background-color: #fff;
  font-size: 5rem;
  font-weight: bold;
  line-height: 1.2;
  color: #1b9131;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}

#main-top .fv-inner__pic--circle .num {
  font-family: din-2014, sans-serif;
  font-size: 7.8rem;
  font-weight: 600;
  line-height: 1;
  position: relative;
  top: 0.5rem;
}

#main-top .fv-inner__pic--circle .small {
  font-size: 3.2rem;
}

@media screen and (max-width: 750px) {
  #main-top .fv {
    padding-top: 0;
  }

  #main-top .fv .c-container {
    padding: 0;
  }

  #main-top .fv-bg {
    top: -26%;
    left: 86%;
    width: 237.6rem;
  }

  #main-top .fv-bgGreen {
    display: none;
  }

  #main-top .fv-inner {
    height: 96.7rem;
    padding-bottom: 5.3rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  #main-top .fv-inner__content {
    position: relative;
    padding: 19.1rem 3rem 6.4rem;
    width: 100%;
    overflow: hidden;
    border-radius: 0 0 15rem 0;
  }

  #main-top .fv-inner__content::before {
    content: "";
    position: absolute;
    width: 100%;
    height: calc(100% - 14.3rem);
    top: 14.3rem;
    left: 0;
    z-index: -1;
    background-color: rgba(27, 145, 49, 0.9);
  }

  #main-top .fv-inner__content-title--sub > span {
    font-size: 3.4rem;
    border-radius: 0 0 6rem 0;
    padding: 1.2rem 2.5rem 1.2rem 1.2rem;
    letter-spacing: 0.065em;
  }

  #main-top .fv-inner__content-title--main {
    margin-top: 1.7rem;
    font-size: 4.2rem;
    line-height: 1.55;
    position: relative;
    z-index: 2;
  }

  #main-top .fv-inner__content-title--main .larg {
    font-size: 8.2rem;
    margin-left: -1rem;
  }

  #main-top .fv-inner__content-title--main .num {
    font-size: 14rem;
    top: 0.8rem;
    margin-left: -1rem;
    letter-spacing: 0;
  }

  #main-top .fv-inner__content-title--main .end {
    width: 100%;
    margin-top: 0.5rem;
    letter-spacing: 0.08em;
  }

  #main-top .fv-inner__content-title--main .label {
    font-size: 3.3rem;
    padding: 0rem 1.1rem 0.4rem;
    margin-left: 0;
    line-height: 1.25;
    top: 0;
    margin-top: 2rem;
  }

  #main-top .fv-inner__content-btn {
    margin: 0;
  }

  #main-top .fv-inner__content-btn--link {
    margin: 0 auto;
    width: 65rem;
    border-radius: 6.5rem;
    min-height: 13.2rem;
    padding: 2rem 3.5rem;
  }

  #main-top .fv-inner__content-btn--text {
    font-size: 4.6rem;
    -webkit-box-flex: 1;
    -ms-flex: 1 auto;
    flex: 1 auto;
    text-align: center;
  }

  #main-top .fv-inner__pic {
    position: absolute;
    top: 18.6rem;
    right: -24.5rem;
    width: 65rem;
    pointer-events: none;
  }

  #main-top .fv-inner__pic--item {
    width: 100%;
    margin: 0;
  }
}

#main-top .concerns {
  position: relative;
}

#main-top .concerns-inner {
  position: relative;
  padding: 10rem 0 20.2rem;
}

#main-top .concerns-inner::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  background-image: url(../img/arrow_down_yellow.png);
  background-repeat: no-repeat;
  background-size: cover;
  width: 21.5rem;
  height: 8rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: -4rem;
  z-index: 1;
  -webkit-animation: arrow 1s infinite;
  animation: arrow 1s infinite;
}

#main-top .concerns-title {
  text-align: center;
}

#main-top .concerns-title > span {
  position: relative;
  padding: 0 6rem;
  font-size: 4.8rem;
  font-weight: bold;
  line-height: 1.2;
  color: #3d3d3d;
}

#main-top .concerns-title > span::before,
#main-top .concerns-title > span::after {
  content: "";
  position: absolute;
  top: 69%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 5.2rem;
  height: 8rem;
  z-index: 1;
}

#main-top .concerns-title > span::before {
  background-image: url(../img/line_title01.png);
  background-repeat: no-repeat;
  background-size: cover;
  left: 0;
}

#main-top .concerns-title > span::after {
  background-image: url(../img/line_title02.png);
  background-repeat: no-repeat;
  background-size: cover;
  right: 1rem;
}

#main-top .concerns-content {
  margin-top: 6.8rem;
}

#main-top .concerns-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#main-top .concerns-list__item {
  width: calc(33.3333333333% - 3rem);
  position: relative;
  padding: 0 1rem;
}

#main-top .concerns-list__item::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  top: 5.5rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  z-index: -1;
}

#main-top .concerns-list__item--icon {
  margin: 0 auto;
  min-height: 23rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#main-top .concerns-list__item--icon img {
  margin: 0 auto;
}

#main-top .concerns-list__item:nth-child(1) {
  width: 33.9rem;
}

#main-top .concerns-list__item:nth-child(1)::before {
  background-image: url(../img/bg_concerns01.png);
  background-repeat: no-repeat;
  background-size: cover;
}

#main-top .concerns-list__item:nth-child(2) .concerns-list__item--icon img {
  width: 25.6rem;
}

#main-top .concerns-list__item:nth-child(2) {
  width: 35.7rem;
}

#main-top .concerns-list__item:nth-child(2)::before {
  background-image: url(../img/bg_concerns02.png);
  background-repeat: no-repeat;
  background-size: cover;
}

#main-top .concerns-list__item:nth-child(3) .concerns-list__item--icon img {
  width: 21.9rem;
}

#main-top .concerns-list__item:nth-child(3) {
  width: 35.7rem;
}

#main-top .concerns-list__item:nth-child(3)::before {
  background-image: url(../img/bg_concerns03.png);
  background-repeat: no-repeat;
  background-size: cover;
}

#main-top .concerns-list__item:nth-child(1) .concerns-list__item--icon img {
  width: 19.5rem;
}

#main-top .concerns-list__item--text {
  margin-top: 2.5rem;
}

#main-top .concerns-list__item--text p {
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.6666666667;
  color: #fff;
  text-align: center;
}

#main-top .concerns-list__item--text p .txt_yellow {
  display: inline;
  color: #ffe971;
}

@media screen and (max-width: 750px) {
  #main-top .concerns-title > span {
    padding: 0 5rem;
    font-size: 4rem;
  }

  #main-top .concerns-title > span::before,
  #main-top .concerns-title > span::after {
    top: 62%;
    width: 4.4rem;
    height: 6.7rem;
  }

  #main-top .concerns-title > span::after {
    right: 0;
  }

  #main-top .concerns-inner {
    padding: 9.8rem 0 14rem;
  }

  #main-top .concerns-inner::before {
    left: 51%;
    bottom: -5rem;
  }

  #main-top .concerns-content {
    margin-top: 8rem;
  }

  #main-top .concerns-list__item {
    width: 100% !important;
    padding: 0 1rem 1rem;
  }

  #main-top .concerns-list__item--icon {
    min-height: 16.8rem;
  }

  #main-top .concerns-list__item:nth-child(1)::before {
    background-image: url(../img/bg_concerns01_sp.png);
    background-repeat: no-repeat;
    background-size: 100%;
    top: 3.5rem;
  }

  #main-top .concerns-list__item:nth-child(2) {
    margin-top: 6.5rem;
  }

  #main-top .concerns-list__item:nth-child(2)::before {
    background-image: url(../img/bg_concerns02_sp.png);
    background-repeat: no-repeat;
    background-size: 100%;
    top: 4.4rem;
  }

  #main-top .concerns-list__item:nth-child(1) {
    padding: 0 1rem 3rem;
  }

  #main-top .concerns-list__item:nth-child(3) {
    margin-top: 9rem;
  }

  #main-top .concerns-list__item:nth-child(3)::before {
    background-image: url(../img/bg_concerns03_sp.png);
    background-repeat: no-repeat;
    background-size: 100%;
  }

  #main-top .concerns-list__item--text {
    margin-top: 2.7rem;
  }

  #main-top .concerns-list__item--text p {
    font-size: 3rem;
    line-height: 1.5333333333;
  }
}

#main-top .solve {
  position: relative;
}

#main-top .solve-bg {
  position: absolute;
  top: 0;
  right: 0;
  height: calc(100% + 65rem);
  width: calc(50vw + 55.2rem + 27rem);
  background-color: rgb(27, 145, 49);
  border-radius: 28rem 0 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .solve-bg::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: url(../img/bg_sec01.png);
  background-size: 192rem 266.6rem;
  background-repeat: no-repeat;
  background-position: -14rem -53rem;
  top: 0;
  left: 0;
  opacity: 0.1;
  z-index: 1;
}

#main-top .solve-title {
  min-height: 13.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#main-top .solve-title > span {
  width: 100%;
  font-weight: bold;
  font-size: 4.8rem;
  line-height: 1.2;
  color: #3d3d3d;
  background-color: #ffdb00;
  text-align: center;
  display: block;
  border-radius: 0 4rem 0 4rem;
  padding: 3.8rem 2rem;
}

#main-top .solve-txt {
  margin: 6.4rem 0 8.7rem;
  text-align: center;
  font-size: 3rem;
  line-height: 1.6666666667;
  color: #fff;
  font-weight: 400;
}

#main-top .solve-inner {
  padding: 12rem 0 13.8rem;
}

#main-top .solve-boxIn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10rem;
  padding: 6.5rem 0;
}

#main-top .solve-boxIn::before {
  content: "";
  position: absolute;
  width: calc(50vw + 55.2rem + 25.2rem);
  height: 100%;
  background-color: #fff;
  z-index: -1;
  top: 0;
  border-radius: 40rem 0 0 40rem;
  left: -15.5rem;
}

#main-top .solve-boxIn__pic {
  width: calc(100% - 74.7rem - 10rem);
}

#main-top .solve-boxIn__pic figure {
  width: 34rem;
  margin-left: -4.5rem;
  margin-top: -4rem;
}

#main-top .solve-boxIn__content {
  width: 74.7rem;
}

#main-top .solve-boxIn__item--txt {
  padding: 3.4rem 2rem 3.4rem 11.2rem;
  padding-left: 9rem;
  position: relative;
  font-size: 3.5rem;
  font-weight: bold;
  line-height: 1.5428571429;
  color: #3d3d3d;
}

#main-top .solve-boxIn__item--txt:not(:last-child) {
  border-bottom: 0.2rem solid rgb(238, 181, 6);
}

#main-top .solve-boxIn__item--txt .txt_green {
  color: #339842;
  display: inline;
}

#main-top .solve-boxIn__item--txt .note {
  display: block;
  text-align: right;
  font-size: 1.4rem;
  font-weight: 400;
  margin-top: 1rem;
}

#main-top .solve-boxIn__item--txt::before {
  content: "";
  position: absolute;
  width: 5.2rem;
  height: 7.7rem;
  left: 0.8rem;
  top: 4.5rem;
  background-image: url(../img/ico_thunder.png);
  background-repeat: no-repeat;
  background-size: cover;
  z-index: 1;
}

@media screen and (max-width: 750px) {
  #main-top .solve-bg {
    height: calc(100% + 15rem);
    width: 100%;
    border-radius: 0 14rem 0 0;
  }

  #main-top .solve-bg::before {
    content: none;
  }

  #main-top .solve-title {
    min-height: auto;
  }

  #main-top .solve-title > span {
    border-radius: 0 5rem 0 5rem;
    padding: 3.8rem 2rem;
    line-height: 1.35;
  }

  #main-top .solve-inner {
    padding: 12rem 0 8.8rem;
  }

  #main-top .solve-txt {
    font-size: 3.2rem;
    line-height: 1.6875;
    max-width: unset;
    margin: 5rem -2rem 9rem -0.5rem;
  }

  #main-top .solve-boxIn {
    display: block;
    padding: 9.5rem 0 6rem;
  }

  #main-top .solve-boxIn::before {
    width: 100vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 14rem 0 14rem 0;
  }

  #main-top .solve-boxIn__pic {
    width: 100%;
    text-align: center;
    padding-left: 4rem;
  }

  #main-top .solve-boxIn__pic figure {
    margin: 0 auto;
  }

  #main-top .solve-boxIn__content {
    width: 100%;
    margin-top: 4.1rem;
  }

  #main-top .solve-boxIn__item--txt {
    padding: 3.6rem 0 3.6rem 8.5rem;
  }

  #main-top .solve-boxIn__item--txt .note {
    font-size: 1.8rem;
    margin-top: 2.5rem;
  }

  #main-top .solve-boxIn__item--txt::before {
    left: 0.8rem;
    top: 4.5rem;
  }
}

#main-top .process {
  position: relative;
}

#main-top .process-bg {
  position: absolute;
  top: 0;
  left: 0;
  height: calc(100% + 109.5rem);
  width: calc(50vw + 55.2rem + 27rem);
  background-color: rgb(248, 248, 248);
  border-radius: 0 28rem 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .process-inner {
  padding: 14.6rem 0 5rem;
}

#main-top .process-heading {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin-top: 6rem;
}

#main-top .process-heading__title {
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #3d3d3d;
  margin-bottom: 5rem;
}

#main-top .process-heading__list {
  max-width: 55.5rem;
  width: 100%;
}

#main-top .process-heading__list-item {
  border-top: 1px solid rgb(57, 159, 64);
  padding: 2.4rem 0 2.4rem 7.2rem;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #000000;
  position: relative;
}

#main-top .process-heading__list-item:last-child {
  border-bottom: 1px solid rgb(57, 159, 64);
}

#main-top .process-heading__list-item::before {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  width: 3.4rem;
  height: 2.9rem;
  background-image: url(../img/ico_check.png);
  background-repeat: no-repeat;
  background-size: cover;
  left: 2.5rem;
  top: 2.5rem;
  z-index: 1;
}

#main-top .process-arrow {
  margin: 4rem 0 3.2rem;
}

#main-top .process-achieve {
  margin-top: 9.6rem;
  border-width: 0.3rem;
  border-color: rgb(27, 145, 49);
  border-style: solid;
  background-color: rgb(255, 255, 255);
  -webkit-box-shadow: 0 0.3rem 0.7rem 0 rgba(0, 0, 0, 0.21);
  box-shadow: 0 0.3rem 0.7rem 0 rgba(0, 0, 0, 0.21);
  padding: 5rem 5rem 6rem;
  border-radius: 4rem;
}

#main-top .process-achieve__title {
  text-align: center;
  margin-top: -3.4rem;
}

#main-top .process-achieve__title > span {
  min-width: 74.6rem;
  min-height: 9.6rem;
  padding: 1rem 3rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 4rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #fff;
  margin-top: -2.8rem;
  background-image: url(../img/bg_title01.png);
  background-repeat: no-repeat;
  background-size: contain;
}

#main-top .process-achieve__desc {
  margin-top: 5.5rem;
}

#main-top .process-achieve__desc > p {
  text-align: center;
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.6666666667;
  color: #3d3d3d;
}

#main-top .process-electricity__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 3.5rem;
}

#main-top .process-electricity__title > span {
  width: 100%;
  font-weight: bold;
  font-size: 4rem;
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: #fff;
  background-color: rgb(27, 145, 49);
  text-align: center;
  display: block;
  border-radius: 0 4rem 0 4rem;
  padding: 2.9rem 2rem;
}

#main-top .process-electricity__boxIn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 4rem;
  border-radius: 3rem;
  background-color: rgb(255, 255, 255);
  -webkit-box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  margin-top: 4.3rem;
  padding: 4.5rem 6rem;
}

#main-top .process-electricity__boxIn--pic {
  width: calc(100% - 55.2rem - 4rem);
  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;
  padding-left: 2.5rem;
  padding-top: 2rem;
}

#main-top .process-electricity__boxIn--pic figure {
  width: 36.4rem;
}

#main-top .process-electricity__boxIn--content {
  width: 55.2rem;
}

#main-top .process-electricity__boxIn--content > .tit {
  font-size: 4rem;
  font-weight: bold;
  line-height: 1.375;
  letter-spacing: 0.06em;
  color: #3d3d3d;
  margin-bottom: 2rem;
}

#main-top .process-electricity__boxIn--content > .txt {
  font-size: 2.4rem;
  line-height: 1.6666666667;
  font-weight: 400;
  color: #3d3d3d;
}

#main-top .process-electricity__boxIn--content > .txt span {
  display: inline;
}

@media screen and (max-width: 750px) {
  #main-top .process-bg {
    height: calc(100% + 145rem);
    width: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    border-radius: 0;
  }

  #main-top .process-inner {
    padding: 10rem 0 7.5rem;
  }

  #main-top .process-heading {
    display: block;
    padding-left: 0;
  }

  #main-top .process-heading__list {
    max-width: 100%;
    margin-top: 6.8rem;
  }

  #main-top .process-heading__list-item {
    padding: 3.1rem 0 3.1rem 7.8rem;
    font-size: 3.2rem;
    letter-spacing: 0;
  }

  #main-top .process-heading__list-item::before {
    width: 5.5rem;
    height: 4.6rem;
    background-image: url(../img/ico_check_sp.png);
    background-repeat: no-repeat;
    background-size: cover;
    left: 1rem;
    top: 2.8rem;
  }

  #main-top .process-arrow {
    margin: 5.5rem 0 3.2rem;
  }

  #main-top .process-achieve {
    /* margin-top: 10.3rem; */
    margin-top: 0;
    padding: 5rem 3rem 7rem;
  }

  #main-top .process-achieve__title {
    margin-top: -6.2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  #main-top .process-achieve__title > span {
    margin-top: 0;
    background-image: url(../img/bg_title01_sp.png);
    background-repeat: no-repeat;
    background-size: contain;
    min-width: 60.4rem;
    min-height: 9.7rem;
  }

  #main-top .process-achieve__desc {
    margin-top: 4.5rem;
  }

  #main-top .process-achieve__desc > p {
    font-size: 3rem;
    line-height: 1.6666666667;
  }

  #main-top .process-electricity__title {
    margin-bottom: 4.2rem;
  }

  #main-top .process-electricity__title > span {
    border-radius: 0 3rem 0 3rem;
    line-height: 1.35;
    padding: 3rem 2rem;
  }

  #main-top .process-electricity__boxIn {
    display: block;
    margin-top: 5.6rem;
    padding: 6rem 2rem 7rem;
  }

  #main-top .process-electricity__boxIn--pic {
    width: 100%;
    padding: 0 0 0 11rem;
  }

  #main-top .process-electricity__boxIn--content {
    width: 100%;
    margin-top: 3.5rem;
  }

  #main-top .process-electricity__boxIn--content > .tit {
    margin-bottom: 3.8rem;
    text-align: center;
  }

  #main-top .process-electricity__boxIn--content > .txt {
    font-size: 3rem;
    line-height: 1.6666666667;
    text-align: center;
  }
}

#main-top .arrow-next {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.4rem;
}

#main-top .arrow-next span {
  width: 2rem;
  height: 2rem;
  border-top: 0.3rem solid #8c8c8c;
  border-right: 0.3rem solid #8c8c8c;
  -webkit-transform: rotate(90deg) translateY(1rem);
  transform: rotate(90deg) translateY(1rem);
  -webkit-animation: animate 2s infinite;
  animation: animate 2s infinite;
}

#main-top .arrow-next span:nth-child(2) {
  -webkit-animation-delay: 0.2s;
  animation-delay: 0.2s;
}

#main-top .arrow-next span:nth-child(3) {
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
}

@media screen and (max-width: 750px) {
  #main-top .arrow-next {
    gap: 0;
  }

  #main-top .arrow-next span {
    width: 2.4rem;
    height: 2.4rem;
  }
}

#main-top .situation {
  position: relative;
}

#main-top .situation-bg {
  position: absolute;
  top: 42rem;
  right: 0;
  height: calc(100% - 3rem);
  width: calc(50vw + 55.2rem + 27rem);
  background-color: rgb(27, 145, 49);
  border-radius: 28rem 0 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .situation-bg::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: url(../img/bg_sec02.jpg);
  background-size: 443.1rem 274.5rem;
  background-repeat: no-repeat;
  background-position: -27rem -43rem;
  top: 0;
  left: 0;
  opacity: 0.1;
  z-index: 1;
}

#main-top .situation-inner {
  padding: 0 0 11.5rem;
}

#main-top .situation-title {
  text-align: center;
  font-size: 4rem;
  color: rgb(27, 145, 49);
  font-weight: bold;
  line-height: 1.521;
}

#main-top .situation-titSub {
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  text-align: center;
  margin-top: 4rem;
}

#main-top .situation-list {
  margin-top: 5.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 3.5rem;
}

#main-top .situation-list__item {
  -webkit-box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  width: calc(25% - 2.625rem);
  border-radius: 1rem;
  overflow: hidden;
  background-color: #fafafa;
  background-image: repeating-linear-gradient(
    -45deg,
    #fafafa,
    #fafafa 0.2rem,
    #f6f6f6 0.2rem,
    #f6f6f6 25%
  );
  background-size: 2em 2em;
}

#main-top .situation-list__item > .tit {
  min-height: 8.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-image: url(../img/bg_titList.png);
  background-repeat: no-repeat;
  background-size: cover;
  padding: 1rem 1rem 2rem;
  font-size: 3.6rem;
  color: rgb(255, 255, 255);
  font-weight: bold;
  line-height: 1.111;
  text-align: center;
}

#main-top .situation-list__item > .txt {
  padding: 2rem 2rem 2.2rem;
  text-align: center;
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
}

#main-top .situation-box {
  background-color: #fff;
  border-radius: 0 6rem 0 6rem;
  padding: 4.3rem;
  margin-top: 9.5rem;
}

#main-top .situation-box__tit {
  text-align: center;
  font-size: 4rem;
  color: rgb(61, 61, 61);
  font-weight: bold;
  line-height: 1.521;
  letter-spacing: 0.05em;
}

#main-top .situation-box__desc {
  margin-top: 1.8rem;
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  text-align: center;
}

#main-top .situation-step {
  margin-top: 4rem;
  background-color: #fff;
  border-radius: 0 6rem 0 6rem;
  padding: 4.4rem 4.4rem 5rem;
}

#main-top .situation-step__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  min-height: 12.6rem;
  background-image: url(../img/step_triangle.png);
  background-repeat: no-repeat;
  background-size: cover;
}

#main-top .situation-step__list--item {
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  font-weight: bold;
  line-height: 1.458;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -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: center;
  -ms-flex-align: center;
  align-items: center;
  width: 33.3333333333%;
}

#main-top .situation-step__list--item > span {
  font-weight: 400;
}

#main-top .situation-step__list--item:nth-child(1) {
  padding-right: 1rem;
}

#main-top .situation-step__list--item:nth-child(2) {
  padding-right: 3rem;
}

#main-top .situation-step__list--item:nth-child(3) {
  padding-right: 2rem;
}

#main-top .situation-step__type {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 4rem;
}

#main-top .situation-step__type--box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 2rem;
}

#main-top .situation-step__type--box .circle {
  width: 13.6rem;
  height: 13.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 0.5rem;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 50%;
  background-color: rgb(220, 245, 225);
  text-align: center;
  font-weight: 500;
  padding-bottom: 0.5rem;
}

#main-top .situation-step__type--box .circle > span {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.4583333333;
  color: rgb(61, 61, 61);
}

#main-top .situation-step__type--box .circle > span.ico {
  width: 4.3rem;
}

#main-top .situation-step__rls {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  gap: 5rem 1.5rem;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 4rem;
  position: relative;
  z-index: 1;
}

#main-top .situation-step__rls::before,
#main-top .situation-step__rls::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  top: 12.8rem;
  z-index: -1;
}

#main-top .situation-step__rls::before {
  width: 12.2rem;
  height: 12.1rem;
  background-image: url(../img/arrow_step01.png);
  background-repeat: no-repeat;
  background-size: cover;
  left: 22rem;
}

#main-top .situation-step__rls::after {
  width: 3.9rem;
  height: 16.1rem;
  background-image: url(../img/arrow_step02.png);
  background-repeat: no-repeat;
  background-size: cover;
  right: 20.5rem;
  top: 9rem;
}

#main-top .situation-step__rls--item {
  min-height: 10rem;
  width: calc(25% - 1.125rem);
  border-radius: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  flex-direction: column;
  gap: 0.4rem;
  font-size: 2.4rem;
  color: rgb(255, 255, 255);
  line-height: 1.458;
  text-align: center;
  padding: 1rem 0.5rem;
}

#main-top .situation-step__rls--item figure.building {
  max-width: 7rem;
}

#main-top .situation-step__rls--item:nth-child(1) {
  width: 13rem;
}

#main-top .situation-step__rls--item:nth-child(2) {
  width: 17rem;
}

#main-top .situation-step__rls--item:nth-child(3) {
  width: 31rem;
  margin: 0 8rem 0 2rem;
}

#main-top .situation-step__rls--item:nth-child(4) {
  width: 15rem;
}

#main-top .situation-step__rls--item:nth-child(5) {
  width: 20rem;
}

#main-top .situation-step__rls--item:nth-child(6) {
  margin-left: 13.5rem;
  width: 17rem;
}

#main-top .situation-step__rls--item:nth-child(7) {
  width: 3.5rem;
}

#main-top .situation-step__rls--item:nth-child(8) {
  width: 22rem;
}

#main-top .situation-step__rls--item.bg_yl {
  background-color: rgb(238, 181, 6);
}

#main-top .situation-step__rls--item.bg_bl {
  background-color: #222e43;
}

#main-top .situation-step__rls--item.bg_gr {
  background-color: #469f39;
}

#main-top .situation-step__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-width: 0.3rem;
  border-color: rgb(27, 145, 49);
  border-style: solid;
  border-radius: 2rem;
  background-color: rgb(255, 255, 255);
  min-height: 11.2rem;
  padding: 1rem 2rem;
  font-size: 3.6rem;
  color: rgb(27, 145, 49);
  line-height: 0.972;
  text-align: center;
  font-weight: 500;
  margin-top: 5rem;
  letter-spacing: 0.05em;
}

#main-top .situation-step__label + .situation-step__label {
  margin-top: 3rem;
}

#main-top .situation-step__label-note {
  width: 100%;
  display: block;
  text-align: right;
  font-weight: 400;
  font-size: 1.6rem;
  color: rgb(61, 61, 61);
  margin-top: 0.6rem;
}

#main-top .situation-step__label-note + .situation-step__label {
  margin-top: 3rem;
}

#main-top .situation-step__note {
  margin-top: 4.5rem;
  padding-right: 4rem;
}

#main-top .situation-step__note > p {
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.583;
  text-align: left;
  font-weight: 400;
  text-indent: -3rem;
  margin-left: 3rem;
  letter-spacing: 0.03em;
}

@media screen and (max-width: 750px) {
  #main-top .situation-bg {
    top: 98.2rem;
    height: calc(100% - 15rem);
    width: 100%;
    background-color: rgb(27, 145, 49);
    border-radius: 0 14rem 0 0;
  }

  #main-top .situation-bg::before {
    content: none;
  }

  #main-top .situation-inner {
    padding: 0 0 10rem;
  }

  #main-top .situation-titSub {
    font-size: 3rem;
    line-height: 1.6666666667;
    margin-top: 3.6rem;
  }

  #main-top .situation-list {
    margin-top: 7.2rem;
    padding: 0 1.8rem;
    gap: 4.5rem 2.6rem;
  }

  #main-top .situation-list__item {
    width: calc(50% - 1.3rem);
    min-height: 35.2rem;
    background-image: repeating-linear-gradient(
      -45deg,
      #fafafa,
      #fafafa 0.2rem,
      #fff 0.2rem,
      #fff 25%
    );
  }

  #main-top .situation-list__item > .tit {
    min-height: 10.7rem;
    padding: 1rem 1rem 2rem;
    font-size: 4.4rem;
    position: relative;
    z-index: 2;
  }

  #main-top .situation-list__item > .tit::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 5rem;
    top: -2.5rem;
    left: 0;
    background-color: #1b9131;
    z-index: -1;
  }

  #main-top .situation-list__item > .txt {
    font-size: 3rem;
  }

  #main-top .situation-box {
    padding: 3rem 2rem 5rem;
    margin-top: 10rem;
  }

  #main-top .situation-box__desc {
    margin-top: 2.6rem;
    font-size: 3rem;
    line-height: 1.35;
    letter-spacing: 0.05em;
  }

  #main-top .situation-step {
    margin-top: 5rem;
    padding: 4.4rem 2rem 4.5rem;
  }

  #main-top .situation-step__list {
    min-height: 8.6rem;
    background-image: url(../img/step_triangle_sp.png);
    background-repeat: no-repeat;
    background-size: 100%;
  }

  #main-top .situation-step__list--item {
    font-size: 2.6rem;
    padding-bottom: 1rem;
  }

  #main-top .situation-step__list--item > span {
    font-size: 2.4rem;
    line-height: 1;
  }

  #main-top .situation-step__list--item:nth-child(1) {
    padding-right: 0;
    width: 33%;
  }

  #main-top .situation-step__list--item:nth-child(2) {
    padding-right: 1rem;
    width: 31%;
  }

  #main-top .situation-step__list--item:nth-child(3) {
    width: 36%;
  }

  #main-top .situation-step__type {
    margin-top: 2rem;
    padding: 0 0.5rem;
  }

  #main-top .situation-step__type--box .circle {
    width: 11.3rem;
    height: 11.3rem;
    padding-bottom: 0;
  }

  #main-top .situation-step__type--box .circle > span {
    line-height: 1.15;
  }

  #main-top .situation-step__type--box .circle > span.ico {
    width: 2.8rem;
  }

  #main-top .situation-step__rls {
    margin-top: 2.5rem;
    padding: 0 0.5rem;
    gap: 4rem 1.5rem;
  }

  #main-top .situation-step__rls--item:nth-child(1) {
    width: 11rem;
  }

  #main-top .situation-step__rls--item:nth-child(2) {
    width: 13rem;
  }

  #main-top .situation-step__rls--item:nth-child(3) {
    width: 12rem;
    margin: 0px 0rem 0 0rem;
  }

  #main-top .situation-step__rls--item:nth-child(4) {
    width: 10rem;
  }

  #main-top .situation-step__rls::before {
    width: 3.9rem;
    height: 16.1rem;
    background-image: url(../img/arrow_step01_sp.png);
    background-repeat: no-repeat;
    background-size: cover;
    left: 19.8rem;
    top: 10.5rem;
  }

  #main-top .situation-step__rls::after {
    width: 2rem;
    height: 5.4rem;
    background-image: url(../img/arrow_step02_sp.png);
    background-repeat: no-repeat;
    background-size: cover;
    right: 18rem;
    top: 12rem;
  }

  #main-top .situation-step__rls--item {
    min-height: 10rem;
    width: calc(25% - 1.125rem);
    line-height: 1.158;
    padding: 1.9rem 0.5rem;
  }

  #main-top .situation-step__rls--item:nth-child(5) {
    width: 18rem;
  }

  #main-top .situation-step__rls--item:nth-child(6) {
    width: 13rem;
    margin-left: 4rem;
  }

  #main-top .situation-step__rls--item:nth-child(7) {
    width: 0;
    padding: 0;
  }

  #main-top .situation-step__rls--item:last-child {
    width: 11rem;
  }

  #main-top .situation-step__label {
    border-radius: 1rem;
    min-height: 7.4rem;
    padding: 2.3rem 2rem;
    font-size: 3.2rem;
    line-height: 1.3125;
    margin-top: 3.8rem;
  }

  #main-top .situation-step__label-note {
    font-size: 1.8rem;
  }

  #main-top .situation-step__label-note + .situation-step__label {
    margin-top: 2rem;
    padding: 1.5rem 2rem;
  }

  #main-top .situation-step__note {
    margin-top: 3.8rem;
    padding-right: 4rem;
  }

  #main-top .situation-step__note > p {
    line-height: 1.4;
    text-indent: -2.4rem;
    margin-left: 2.4rem;
  }
}

#main-top .benefit {
  position: relative;
}

#main-top .benefit-bg {
  position: absolute;
  top: 0;
  left: 0;
  height: calc(100% + 85.5rem);
  width: calc(50vw + 55.2rem + 27rem);
  background-color: rgb(248, 248, 248);
  border-radius: 0 28rem 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .benefit-inner {
  padding: 11rem 0;
}

#main-top .benefit-title {
  font-size: 4rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  color: #3d3d3d;
}

#main-top .benefit-content {
  margin-top: 6.8rem;
}

#main-top .benefit-arrow {
  margin: 3.6rem 0;
}

#main-top .benefit-boxIn {
  background-color: rgb(255, 255, 255);
  -webkit-box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  box-shadow: 0px 0px 2.1rem 0px rgba(0, 0, 0, 0.04);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 11rem;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 7.2rem 4rem;
}

#main-top .benefit-boxIn__content {
  width: 57rem;
  text-align: left;
}

#main-top .benefit-boxIn__content--title > span {
  min-width: 28.5rem;
  min-height: 7rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: rgb(27, 145, 49);
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1.3;
  color: #fff;
  border-radius: 0 4rem 0 4rem;
}

#main-top .benefit-boxIn__content--title > span .num {
  font-family: din-2014, sans-serif;
  font-family: din-2014, sans-serif;
  font-size: 5rem;
  font-weight: 500;
  line-height: 1;
}

#main-top .benefit-boxIn__content--titSub {
  font-size: 3.6rem;
  color: rgb(61, 61, 61);
  font-weight: bold;
  line-height: 1.389;
  margin-top: 2.6rem;
}

#main-top .benefit-boxIn__content--txt {
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  font-weight: 400;
  margin-top: 2.2rem;
}

@media screen and (min-width: 751px) {
  #main-top .benefit-boxIn__content--txt > a:hover {
    opacity: 0.6;
  }
}

#main-top .benefit-boxIn__content--note {
  margin-top: 3rem;
  padding: 1.8rem 2.5rem;
  background-color: rgb(255, 250, 211);
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.3333333333;
  letter-spacing: 0;
  color: #3d3d3d;
}

#main-top .benefit-boxIn.--01 .benefit-boxIn__pic figure {
  width: 27.6rem;
}

#main-top .benefit-boxIn.--02 .benefit-boxIn__pic figure {
  width: 35.1rem;
}

#main-top .benefit-boxIn.--03 .benefit-boxIn__pic figure {
  width: 24.8rem;
}

#main-top .benefit-boxIn.--04 .benefit-boxIn__pic {
  margin-top: 5rem;
  margin-right: 2rem;
}

#main-top .benefit-boxIn.--04 .benefit-boxIn__pic figure {
  width: 36.2rem;
}

#main-top .benefit-boxIn.--05 {
  margin-top: 6.2rem;
}

#main-top .benefit-boxIn.--05 .benefit-boxIn__pic figure {
  width: 31.3rem;
}

#main-top .benefit-boxIn.--05 .benefit-boxIn__content {
  width: 60rem;
}

#main-top .benefit-boxIn.--01,
#main-top .benefit-boxIn.--03,
#main-top .benefit-boxIn.--05 {
  border-radius: 10rem 0 10rem 0;
}

#main-top .benefit-boxIn.--02,
#main-top .benefit-boxIn.--04 {
  padding: 7.2rem 4rem 9.8rem;
  border-radius: 0 10rem 0 10rem;
  margin-top: 6.2rem;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

#main-top .benefit-boxIn.--02 .benefit-boxIn__content,
#main-top .benefit-boxIn.--04 .benefit-boxIn__content {
  text-align: right;
}

#main-top .bnfOther .accordion-content,
#main-top .benefit-reduction .accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  position: relative;
}

#main-top .bnfOther .accordion-content {
  margin: 0 auto 8.5rem;
}

#main-top .benefit-reduction__title {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 3.5rem;
}

#main-top .bnfOther__title.accordion-header,
#main-top .benefit-reduction__title.accordion-header {
  cursor: pointer;
}

#main-top .bnfOther__title .icon,
#main-top .benefit-reduction__title .icon {
  width: 4.5rem;
  height: 4.5rem;
  position: absolute;
  right: 5rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  border-radius: 50%;
  background-color: #fff;
  padding: 0;
}

#main-top .bnfOther__title .icon::before,
#main-top .benefit-reduction__title .icon::before {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 0.3rem;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  background-color: rgb(27, 145, 49);
}

#main-top .bnfOther__title .icon::after,
#main-top .benefit-reduction__title .icon::after {
  content: "";
  position: absolute;
  height: 2.5rem;
  width: 0.3rem;
  left: 51%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease,
    -webkit-transform 0.3s ease;
  background-color: rgb(27, 145, 49);
}

#main-top .bnfOther__title.active .icon::after,
#main-top .benefit-reduction__title.active .icon::after {
  opacity: 0;
  -webkit-transform: translateY(-50%) rotate(90deg);
  transform: translateY(-50%) rotate(90deg);
}

#main-top .benefit-reduction__title > span {
  width: 100%;
  font-weight: bold;
  font-size: 4rem;
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: #fff;
  background-color: rgb(27, 145, 49);
  text-align: center;
  display: block;
  border-radius: 0 4rem 0 4rem;
  padding: 2.9rem 2rem;
}

#main-top .benefit-reduction__titSub {
  border-width: 0.3rem;
  border-color: rgb(27, 145, 49);
  border-style: solid;
  border-radius: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  min-height: 7.5rem;
  padding: 1rem;
  font-size: 2.4rem;
  font-weight: bold;
  color: #3d3d3d;
  margin-top: 5rem;
}

#main-top .benefit-reduction__table {
  margin-top: 5.5rem;
}

#main-top .benefit-reduction__table--inner {
  overflow: hidden;
  border-width: 0.3rem;
  border-color: rgb(238, 181, 6);
  border-style: solid;
  border-radius: 2rem;
}

#main-top .benefit-reduction__table table {
  width: 100%;
  background-color: rgb(255, 255, 255);
}

#main-top .benefit-reduction__table table th,
#main-top .benefit-reduction__table table td {
  vertical-align: middle;
}

#main-top .benefit-reduction__table table th {
  background-color: rgb(238, 181, 6);
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.2;
  color: #3d3d3d;
  height: 7.5rem;
}

#main-top .benefit-reduction__table table th:not(:last-child) {
  border-right: 1px solid rgba(141, 141, 141, 0.2);
}

#main-top .benefit-reduction__table table th:nth-child(1),
#main-top .benefit-reduction__table table td:nth-child(1) {
  width: 66rem;
}

#main-top .benefit-reduction__table table th:nth-child(2),
#main-top .benefit-reduction__table table td:nth-child(2) {
  width: 21.8rem;
}

#main-top .benefit-reduction__table table th:nth-child(3),
#main-top .benefit-reduction__table table td:nth-child(3) {
  width: calc(100% - 21.8rem - 66rem);
}

#main-top .benefit-reduction__table table td {
  text-align: center;
  padding: 3.2rem 2.7rem;
  position: relative;
}

#main-top .benefit-reduction__table table td .bold {
  font-weight: bold;
}

#main-top .benefit-reduction__table table td .bold.mgb10 {
  margin-bottom: 1rem;
}

#main-top
  .benefit-reduction__table
  table
  td:nth-child(1):not(.no-triangle)::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 94%;
  width: 0;
  height: 0;
  border-right: 1.5rem solid transparent;
  border-left: 1.5rem solid transparent;
  border-top: 2rem solid rgb(61, 61, 61);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

#main-top .benefit-reduction__table table td.bg-full {
  position: relative;
}

#main-top .benefit-reduction__table table td.bg-full::before {
  content: "";
  position: absolute;
  width: calc(100% - 5.4rem);
  height: calc(100% - 5.4rem);
  border-radius: 0.6rem;
  background-color: rgb(255, 242, 203);
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 1;
}

#main-top .benefit-reduction__table table td > span {
  position: relative;
  z-index: 2;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #3d3d3d;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 100%;
  min-height: 6rem;
  padding: 1.5rem;
}

#main-top .benefit-reduction__table table td .bg_green {
  border-radius: 0.6rem;
  background-color: rgb(189, 225, 196);
}

#main-top .benefit-reduction__table table td .bg_yellow {
  border-radius: 0.6rem;
  background-color: rgb(255, 242, 203);
}

#main-top .benefit-reduction__table table td .bg_gray {
  border-radius: 0.6rem;
  background-color: rgb(226, 231, 227);
}

#main-top .benefit-reduction__table table td:not(.o-br) {
  border-bottom: 1px solid rgba(141, 141, 141, 0.2);
  border-right: 1px solid rgba(141, 141, 141, 0.2);
}

#main-top .benefit-reduction__table--note {
  font-size: 1.4rem;
  color: rgb(125, 125, 125);
  line-height: 1.2;
  text-align: left;
  margin-top: 3rem;
}

@media screen and (max-width: 750px) {
  #main-top .benefit-bg {
    height: calc(100% + 55rem);
    width: 100%;
    border-radius: 14rem 0 0 0;
  }

  #main-top .benefit-inner {
    padding: 9.5rem 0;
  }

  #main-top .benefit-content {
    margin-top: 6rem;
  }

  #main-top .benefit-arrow {
    margin: 5.2rem 0 3.5rem;
  }

  #main-top .benefit-boxIn {
    display: block;
    padding: 7.5rem 2rem 7.5rem 6.2rem;
    position: relative;
  }

  #main-top .benefit-boxIn__content {
    width: 100%;
  }

  #main-top .benefit-boxIn__content--title > span {
    border-radius: 0 4rem 0 4rem;
  }

  #main-top .benefit-boxIn__content--titSub {
    font-size: 4rem;
    margin-top: 3.8rem;
    line-height: 1.25;
  }

  #main-top .benefit-boxIn__content--txt {
    font-size: 3rem;
    margin-top: 3rem;
  }

  #main-top .benefit-boxIn__content--note {
    padding: 3rem 1.9rem;
    font-size: 3rem;
    line-height: 1.667;
    text-align: center;
    max-width: calc(100% - 4.2rem);
    margin: 4rem auto 0 0;
  }

  #main-top .benefit-boxIn__pic {
    position: absolute;
  }

  #main-top .benefit-boxIn.--01 .benefit-boxIn__pic {
    right: 5.5rem;
  }

  #main-top .benefit-boxIn.--01 .benefit-boxIn__pic figure {
    width: 17.5rem;
  }

  #main-top .benefit-boxIn.--02 .benefit-boxIn__pic {
    top: 6rem;
    left: 6.5rem;
  }

  #main-top .benefit-boxIn.--02 .benefit-boxIn__pic figure {
    width: 26.6rem;
  }

  #main-top .benefit-boxIn.--03 .benefit-boxIn__pic {
    right: 8.2rem;
    top: 4.6rem;
  }

  #main-top .benefit-boxIn.--03 .benefit-boxIn__pic figure {
    width: 17.4rem;
  }

  #main-top .benefit-boxIn.--04 .benefit-boxIn__pic {
    margin-top: 0;
    margin-right: 0;
    left: 6.8rem;
    top: 6.6rem;
  }

  #main-top .benefit-boxIn.--04 .benefit-boxIn__pic figure {
    width: 26.9rem;
  }

  #main-top .benefit-boxIn.--05 {
    margin-top: 6.2rem;
  }

  #main-top .benefit-boxIn.--05 .benefit-boxIn__pic {
    top: 7rem;
    right: 5rem;
  }

  #main-top .benefit-boxIn.--05 .benefit-boxIn__pic figure {
    width: 25.8rem;
  }

  #main-top .benefit-boxIn.--05 .benefit-boxIn__content {
    width: 100%;
  }

  #main-top .benefit-boxIn.--01,
  #main-top .benefit-boxIn.--03,
  #main-top .benefit-boxIn.--05 {
    border-radius: 7.5rem 0 7.5rem 0;
  }

  #main-top .benefit-boxIn.--02,
  #main-top .benefit-boxIn.--04 {
    border-radius: 0 7.5rem 0 7.5rem;
    padding: 7rem 6.2rem 7.5rem 2rem;
    margin-top: 5rem;
  }

  #main-top .benefit-boxIn.--02 .benefit-boxIn__content,
  #main-top .benefit-boxIn.--04 .benefit-boxIn__content {
    text-align: right;
  }

  #main-top .benefit-boxIn.--02 .benefit-boxIn__content--note,
  #main-top .benefit-boxIn.--04 .benefit-boxIn__content--note {
    margin: 4rem 0 0 auto;
  }

  #main-top .benefit-reduction__title > span {
    border-radius: 0 3rem 0 3rem;
  }

  #main-top .bnfOther__title .icon,
  #main-top .benefit-reduction__title .icon {
    right: 4rem;
  }

  #main-top .benefit-reduction__title + .benefit-arrow {
    margin: 4.3rem 0 3rem;
  }

  #main-top .benefit-reduction__titSub {
    min-height: 13.2rem;
    line-height: 1.4;
    font-size: 3rem;
    margin-top: 4.8rem;
    text-align: center;
  }

  #main-top .benefit-reduction__table {
    margin: 4rem 0 8rem;
  }

  #main-top .benefit-reduction__table table th {
    font-size: 2.8rem;
  }

  #main-top .benefit-reduction__table table th:nth-child(1),
  #main-top .benefit-reduction__table table td:nth-child(1) {
    width: 41.8rem;
  }

  #main-top .benefit-reduction__table table th:nth-child(2),
  #main-top .benefit-reduction__table table td:nth-child(2) {
    width: 11.5rem;
  }

  #main-top .benefit-reduction__table table th:nth-child(3),
  #main-top .benefit-reduction__table table td:nth-child(3) {
    width: calc(100% - 11.5rem - 41.8rem);
  }

  #main-top .benefit-reduction__table table td {
    padding: 2.4rem 1rem;
  }

  #main-top
    .benefit-reduction__table
    table
    td:nth-child(1):not(.no-triangle)::before {
    border-right: 1rem solid transparent;
    border-left: 1rem solid transparent;
    border-top: 1.5rem solid rgb(61, 61, 61);
  }

  #main-top .benefit-reduction__table table td.bg-full {
    position: relative;
  }

  #main-top .benefit-reduction__table table td.bg-full::before {
    content: "";
    position: absolute;
    width: calc(100% - 5.4rem);
    height: calc(100% - 5.4rem);
    border-radius: 0.6rem;
    background-color: rgb(255, 242, 203);
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 1;
  }

  #main-top .benefit-reduction__table table td > span {
    font-size: 2.4rem;
    line-height: 1.1;
    min-height: 4rem;
    padding: 0;
  }

  #main-top .benefit-reduction__table table td > span .small {
    font-size: 2rem;
    display: inline;
  }

  #main-top .benefit-reduction__table table td.bg-full,
  #main-top .benefit-reduction__table table td.sp-bg_yellow {
    background-color: rgb(255, 242, 203);
  }

  #main-top .benefit-reduction__table table td.bg-full > span,
  #main-top .benefit-reduction__table table td.sp-bg_yellow > span {
    line-height: 1.4090909091;
  }

  #main-top .benefit-reduction__table table td .bg_green,
  #main-top .benefit-reduction__table table td .bg_yellow,
  #main-top .benefit-reduction__table table td .bg_gray {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  #main-top .benefit-reduction__table--note {
    font-size: 1.8rem;
    line-height: 1.3333333333;
    margin-top: 3rem;
  }
}

#main-top .bnfOther {
  position: relative;
  z-index: 2;
}

#main-top .bnfOther-bg {
  position: absolute;
  top: 0;
  right: 0;
  height: calc(100% + 50vh);
  width: calc(50vw + 55.2rem + 20rem);
  background-color: rgb(255, 255, 255);
  border-radius: 28rem 0 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .bnfOther-inner {
  padding: 11rem 0 14rem;
}

#main-top .bnfOther-arrow {
  margin: 6rem 0;
}

#main-top .bnfOther-arrow.--01 {
  margin-top: -14rem;
}

#main-top .bnfOther__title {
  width: 100%;
  font-weight: bold;
  font-size: 4rem;
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: #fff;
  background-color: rgb(27, 145, 49);
  text-align: center;
  display: block;
  border-radius: 0 4rem 0 4rem;
  padding: 2.9rem 2rem;
  position: relative;
}

#main-top .bnfOther__titleSub {
  width: 100%;
  font-weight: bold;
  font-size: 4rem;
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: #fff;
  background-color: rgb(238, 181, 6);
  text-align: center;
  display: block;
  border-radius: 4rem 4rem 0 0;
  padding: 2.9rem 2rem;
}

#main-top .bnfOther__note {
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 400;
  color: #3d3d3d;
  margin-top: 4rem;
}

#main-top .bnfOther__list {
  margin: 4rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#main-top .bnfOther__list-item {
  width: 20.1rem;
  overflow: hidden;
  border-width: 0.1rem;
  border-color: rgb(191, 191, 191);
  border-style: solid;
  background-color: rgb(234, 234, 234);
}

#main-top .bnfOther__list-item:nth-child(1) {
  width: 23rem;
}

#main-top .bnfOther__list-item:nth-child(2) {
  width: 30.3rem;
  border-width: 0.2rem;
  border-color: rgb(27, 145, 49);
  border-style: solid;
  background-color: rgb(230, 247, 233);
  margin: 0 0.8rem;
}

#main-top .bnfOther__list-item:nth-child(2) .bnfOther__list-item--tit {
  background-color: rgb(53, 170, 75);
  font-size: 4rem;
  color: rgb(255, 255, 255);
}

#main-top
  .bnfOther__list-item:nth-child(2)
  .bnfOther__list-item--content
  > span {
  font-size: 2.4rem;
  font-weight: bold;
}

#main-top
  .bnfOther__list-item:nth-child(2)
  .bnfOther__list-item--content
  > span:not(:last-child) {
  border-bottom: 1px solid rgb(175, 214, 182);
}

#main-top .bnfOther__list-item--tit {
  background-color: rgb(214, 214, 214);
  min-height: 8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 1rem;
  font-size: 3rem;
  color: rgb(61, 61, 61);
  font-weight: bold;
  line-height: 1.3;
  text-align: center;
}

#main-top .bnfOther__list-item--content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#main-top .bnfOther__list-item--content > span {
  font-size: 2rem;
  color: rgb(61, 61, 61);
  line-height: 1.3;
  letter-spacing: 0;
  font-weight: 400;
  padding: 1rem 0.8rem;
  min-height: 7.3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

#main-top .bnfOther__list-item--content > span:nth-child(1) {
  min-height: 10rem;
}

#main-top .bnfOther__list-item--content > span:not(:last-child) {
  border-bottom: 1px solid rgb(191, 191, 191);
}

#main-top .bnfOther__list-item--content > span .emoji {
  font-family: "Noto Color Emoji", sans-serif;
  margin-right: 1rem;
}

#main-top .bnfOther__list-item--content > span .note {
  width: 100%;
  font-size: 1.4rem;
  line-height: 1.2857142857;
  font-weight: 400;
  margin-top: 0.5rem;
}

#main-top .bnfOther__titSecond {
  font-size: 4rem;
  color: #3d3d3d;
  line-height: 1.521;
  text-align: center;
  font-weight: 500;
  margin-bottom: 4rem;
  letter-spacing: 0.06em;
}

#main-top .bnfOther__desc {
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  text-align: center;
  font-weight: 400;
  margin-bottom: 5rem;
}

#main-top .bnfOther__regions {
  position: relative;
  max-width: 93rem;
  width: 100%;
  margin: 0 auto 5rem;
  border-width: 0.2rem;
  border-color: rgb(203, 203, 203);
  border-style: solid;
  border-radius: 1rem;
  background-color: rgb(248, 255, 249);
  padding: 5.2rem 5.4rem 4.6rem;
}

#main-top .bnfOther__regions-notes {
  position: absolute;
  top: 1.8rem;
  right: 1.8rem;
  min-width: 16rem;
  border: 0.2rem solid rgb(203, 203, 203);
  border-radius: 0.5rem;
  padding: 0.6rem 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 0.8rem;
}

#main-top .bnfOther__regions-notes__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 1.5rem;
}

#main-top .bnfOther__regions-notes__item .icon {
  width: 3.4rem;
  height: 1.6rem;
  position: relative;
}

#main-top .bnfOther__regions-notes__item .icon.--yellow {
  background-color: #ffdb00;
}

#main-top .bnfOther__regions-notes__item .icon.--yellow::before {
  border-left: 0.8rem solid #ffdb00;
}

#main-top .bnfOther__regions-notes__item .icon.--green {
  background-color: #35aa4b;
}

#main-top .bnfOther__regions-notes__item .icon.--green::before {
  border-left: 0.6rem solid #35aa4b;
}

#main-top .bnfOther__regions-notes__item .icon::before {
  content: "";
  position: absolute;
  left: 100%;
  top: 0%;
  width: 0;
  height: 0;
  border-top: 0.8rem solid transparent;
  border-bottom: 0.8rem solid transparent;
}

#main-top .bnfOther__regions-notes__item .text {
  font-size: 1.8rem;
  color: rgb(61, 61, 61);
  line-height: 1;
}

#main-top .bnfOther__regions-tit {
  text-align: center;
  margin-bottom: 5rem;
}

#main-top .bnfOther__regions-tit > span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-width: 0.2rem;
  border-color: rgb(255, 219, 0);
  border-style: solid;
  background-color: rgb(255, 255, 255);
  font-size: 2.4rem;
  font-weight: 400;
  color: #3d3d3d;
  line-height: 1;
  background-color: rgb(255, 255, 255);
  padding: 0.5rem 1rem;
  min-width: 15.5rem;
  min-height: 5.2rem;
  border-radius: 0.5rem;
  position: relative;
}

#main-top .bnfOther__regions-tit > span:after,
#main-top .bnfOther__regions-tit > span:before {
  border: solid transparent;
  content: " ";
  display: block;
  height: 0;
  position: absolute;
  pointer-events: none;
  width: 0;
  top: 100%;
}

#main-top .bnfOther__regions-tit > span:before {
  border-color: rgba(255, 255, 255, 0);
  border-top-color: rgb(255, 219, 0);
  left: 50%;
  margin-left: -1.3rem;
  border-width: 1.3rem;
}

#main-top .bnfOther__regions-tit > span:after {
  border-color: rgba(255, 255, 255, 0);
  border-top-color: #fff;
  left: 50%;
  margin-left: -1.1rem;
  border-width: 1.1rem;
}

#main-top .bnfOther__regions-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 2rem 0;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

#main-top .bnfOther__regions-list__item > span {
  height: 5rem;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 0.5rem 0 0 0.5rem;
  min-width: 33rem;
}

#main-top .bnfOther__regions-list__item > span::before {
  content: "";
  position: absolute;
  left: 100%;
  top: 0%;
  width: 0;
  height: 0;
  border-top: 2.5rem solid transparent;
  border-bottom: 2.5rem solid transparent;
}

#main-top .bnfOther__regions-list__item.--yellow > span {
  background-color: #ffdb00;
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  text-align: center;
}

#main-top .bnfOther__regions-list__item.--yellow > span::before {
  border-left: 1.5rem solid #ffdb00;
}

#main-top .bnfOther__regions-list__item.--green > span {
  background-color: #35aa4b;
  font-size: 2.4rem;
  color: #fff;
  line-height: 1.667;
  text-align: center;
}

#main-top .bnfOther__regions-list__item.--green > span::before {
  border-left: 1.5rem solid #35aa4b;
}

#main-top .bnfOther__regions-list__item.--rls {
  width: calc(100% - 50rem);
}

#main-top .bnfOther__regions-list__item.--rls > span {
  min-width: 100%;
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.667;
  text-align: center;
  margin-top: 3.8rem;
}

#main-top .bnfOther__regions-list__item.--rls > span.ico {
  width: 6.6rem;
  height: 6.6rem;
  min-width: 6.6rem;
  margin: 0 auto;
}

#main-top .bnfOther__regions-list__item.--rls > span.ico + .--02 {
  margin-top: 0;
}

#main-top .bnfOther__regions-list__item.--rls > span.ico + .--02 .line::before,
#main-top .bnfOther__regions-list__item.--rls > span.ico + .--02 .line::after {
  height: 4rem;
}

#main-top .bnfOther__regions-list__item.--rls > span .line {
  border-width: 0 0 0.2rem 0;
  border-color: rgb(53, 170, 75);
  border-style: solid;
  position: absolute;
  bottom: 0;
  left: 1.2rem;
  width: 97%;
  height: 2rem;
}

#main-top .bnfOther__regions-list__item.--rls > span .line::before,
#main-top .bnfOther__regions-list__item.--rls > span .line::after {
  content: "";
  position: absolute;
  width: 0.2rem;
  background-color: rgb(53, 170, 75);
  height: 100%;
  bottom: 0;
}

#main-top .bnfOther__regions-list__item.--rls > span .line::before {
  left: 0;
}

#main-top .bnfOther__regions-list__item.--rls > span .line::after {
  right: 0;
}

#main-top .bnfOther__regions-list__item:last-child > span {
  min-width: 17rem;
}

#main-top .bnfOther__regions-list.--02 > li:nth-child(1),
#main-top .bnfOther__regions-list.--02 > li:nth-child(3) {
  min-width: 35.7rem;
}

#main-top .bnfOther__regions-list.--02 > li.--rls {
  width: calc(100% - 53rem);
}

#main-top .bnfOther__regions-box {
  background-color: #ffea94;
  border-radius: 1rem;
  font-size: 2.4rem;
  color: rgb(61, 61, 61);
  line-height: 1.458;
  font-weight: 500;
  text-align: center;
  padding: 1.5rem;
  margin-top: 5rem;
}

#main-top .bnfOther__regions-text {
  font-size: 2rem;
  color: rgb(61, 61, 61);
  line-height: 1.45;
  text-align: left;
  margin-top: 2rem;
}

#main-top .bnfOther__cmt {
  margin-top: 7.8rem;
  padding: 0 2.5rem;
}

#main-top .bnfOther__cmt-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 5rem;
}

#main-top .bnfOther__cmt-box + .bnfOther__cmt-box {
  margin-top: 6.5rem;
}

#main-top .bnfOther__cmt-box--avt {
  width: 16.8rem;
}

#main-top .bnfOther__cmt-box--content {
  width: calc(100% - 16.8rem - 5rem);
  padding: 3rem 4.7rem;
  position: relative;
  border: 0.5rem solid rgb(53, 170, 75);
  border-radius: 3rem;
}

#main-top .bnfOther__cmt-box--content > p {
  font-size: 2.4rem;
  font-weight: 400;
  color: rgb(61, 61, 61);
  line-height: 1.72;
  text-align: left;
  position: relative;
  z-index: 3;
}

#main-top .bnfOther__cmt-box--content::before,
#main-top .bnfOther__cmt-box--content::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  pointer-events: none;
  width: 9.4rem;
  height: 8.4rem;
  background-color: #fff;
  z-index: 1;
}

#main-top .bnfOther__cmt-box--content::before {
  background-image: url(../img/txt_testimonials01.png);
  background-repeat: no-repeat;
  background-size: 4.2rem 3.1rem;
  background-position: center;
  left: -4rem;
  top: -3.5rem;
}

#main-top .bnfOther__cmt-box--content::after {
  background-repeat: no-repeat;
  background-size: 4.2rem 3.1rem;
  background-position: center;
  background-image: url(../img/txt_testimonials02.png);
  right: -3.5rem;
  bottom: -2.5rem;
}

@media screen and (max-width: 750px) {
  #main-top .bnfOther-bg {
    top: 25rem;
    height: calc(100% + 15rem);
    width: 100%;
    border-radius: 14rem 0 0 0;
  }

  #main-top .bnfOther__title {
    border-radius: 0 3rem 0 3rem;
    padding: 2.9rem 1rem;
    letter-spacing: 0;
  }

  #main-top .bnfOther__title + .bnfOther-arrow {
    margin: 4.2rem 0 7.5rem;
  }

  #main-top .bnfOther__titleSub {
    border-radius: 0 3rem 0 3rem;
  }

  #main-top .bnfOther .bnfOther-arrow.--03 {
    margin: 3.5rem 0 5.2rem;
  }

  #main-top .bnfOther__note {
    font-size: 2.4rem;
    line-height: 1.2916666667;
    margin-top: 2.5rem;
    text-align: center;
  }

  #main-top .bnfOther-inner {
    padding: 8.4rem 0 10.5rem;
  }

  #main-top .bnfOther__table {
    width: calc(100% + 3rem);
  }

  #main-top .bnfOther__table + .bnfOther-arrow {
    margin: 8rem 0 3.4rem;
  }

  #main-top .bnfOther__table-inner {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  #main-top .bnfOther__table-scroll {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }

  #main-top .bnfOther__list {
    margin: 4rem 0 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  #main-top .bnfOther__list-item {
    width: 21.7rem;
  }

  #main-top .bnfOther__list-item:nth-child(1) {
    width: 20.2rem;
  }

  #main-top .bnfOther__list-item:nth-child(2) {
    width: 27rem;
  }

  #main-top .bnfOther__list-item--content > span:nth-child(4) {
    min-height: 13rem;
  }

  #main-top .bnfOther__list-item:nth-child(2) .bnfOther__list-item--tit {
    font-size: 3.8rem;
  }

  #main-top
    .bnfOther__list-item:nth-child(2)
    .bnfOther__list-item--content
    > span {
    font-size: 3rem;
  }

  #main-top .bnfOther__list-item--tit {
    min-height: 7.8rem;
  }

  #main-top .bnfOther__list-item--content > span {
    font-size: 2.8rem;
    padding: 1rem 0.5rem;
    min-height: 11rem;
    text-align: center;
    display: block;
    -ms-flex-line-pack: center;
    align-content: center;
  }

  #main-top .bnfOther__list-item--content > span:nth-child(1) {
    min-height: 17rem;
  }

  #main-top .bnfOther__list-item--content > span .note {
    font-size: 2rem;
    margin-top: 1.5rem;
  }

  #main-top .bnfOther__desc {
    font-size: 3rem;
    margin-bottom: 6.8rem;
  }

  #main-top .bnfOther__regions {
    max-width: 100%;
    margin: 0 auto 5rem;
    padding: 6.5rem 3.2rem 2.5rem 1.8rem;
  }

  #main-top .bnfOther .accordion-content {
    margin: 0 auto 6.4rem;
  }

  #main-top .bnfOther__regions-notes {
    top: 2.4rem;
    right: 1rem;
    min-width: 18.2rem;
    border: 0.1rem solid rgb(203, 203, 203);
    padding: 0.8rem 1.3rem;
    gap: 1.4rem;
  }

  #main-top .bnfOther__regions-notes__item .icon {
    height: 1.8rem;
  }

  #main-top .bnfOther__regions-notes__item .icon.--yellow::before {
    border-left: 0.6rem solid #ffdb00;
  }

  #main-top .bnfOther__regions-notes__item .icon.--green::before {
    border-left: 0.6rem solid #35aa4b;
  }

  #main-top .bnfOther__regions-notes__item .icon::before {
    border-top: 0.9rem solid transparent;
    border-bottom: 0.9rem solid transparent;
  }

  #main-top .bnfOther__regions-notes__item .text {
    font-size: 2rem;
  }

  #main-top .bnfOther__regions-tit {
    margin-bottom: 5rem;
  }

  #main-top .bnfOther__regions-tit > span {
    font-size: 3rem;
    min-width: 17.5rem;
    min-height: 5.6rem;
  }

  #main-top .bnfOther__regions-list {
    gap: 2.6rem 0;
  }

  #main-top .bnfOther__regions-list__item > span {
    height: auto;
    line-height: 1.3333333333 !important;
    min-height: 7rem;
    min-width: 24.4rem;
  }

  #main-top .bnfOther__regions-list__item > span::before {
    border-top: 3.5rem solid transparent;
    border-bottom: 3.5rem solid transparent;
  }

  #main-top .bnfOther__regions-list__item.--yellow > span {
    font-size: 3rem;
    padding: 1rem 0.5rem;
  }

  #main-top .bnfOther__regions-list__item.--yellow > span::before {
    border-left: 2rem solid #ffdb00;
  }

  #main-top .bnfOther__regions-list__item.--green > span {
    font-size: 3rem;
    padding: 1rem 0.5rem;
  }

  #main-top .bnfOther__regions-list__item.--green > span::before {
    border-left: 2rem solid #35aa4b;
  }

  #main-top .bnfOther__regions-list__item.--rls {
    width: calc(100% - 35rem);
  }

  #main-top .bnfOther__regions-list__item.--rls > span {
    font-size: 3rem;
    margin-top: 3.8rem;
  }

  #main-top .bnfOther__regions-list__item.--rls > span.ico {
    width: 8.3rem;
    height: 8.3rem;
    min-width: 8.3rem;
  }

  #main-top .bnfOther__regions-list__item.--rls > span.ico + .--02 {
    margin-top: 0;
    min-height: auto;
    padding: 0 0 1.2rem 0;
  }

  #main-top
    .bnfOther__regions-list__item.--rls
    > span.ico
    + .--02
    .line::before,
  #main-top
    .bnfOther__regions-list__item.--rls
    > span.ico
    + .--02
    .line::after {
    height: 2rem;
  }

  #main-top .bnfOther__regions-list__item.--rls > span .line {
    left: 1.2rem;
  }

  #main-top .bnfOther__regions-list__item:last-child > span {
    min-width: 10.5rem;
  }

  #main-top .bnfOther__regions-list.--02 > li:nth-child(1),
  #main-top .bnfOther__regions-list.--02 > li:nth-child(3) {
    min-width: 24.4rem;
  }

  #main-top .bnfOther__regions-list.--02 > li.--rls {
    width: calc(100% - 36rem);
    padding-left: 2rem;
  }

  #main-top .bnfOther__regions-list.--02 > li.--rls > span .line {
    left: -0.5rem;
    width: 103%;
  }

  #main-top .bnfOther__regions-box {
    font-size: 3rem;
    line-height: 1.5;
    padding: 2rem 1.5rem;
    margin-top: 4rem;
    width: 97.5%;
    margin-left: auto;
  }

  #main-top .bnfOther__regions-text {
    font-size: 2.3rem;
    line-height: 1.4166666667;
    margin-top: 1.5rem;
  }

  #main-top .bnfOther__cmt {
    margin-top: 4rem;
    padding: 0 0.5rem;
  }

  #main-top .bnfOther__cmt-box {
    -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;
    gap: 0;
  }

  #main-top .bnfOther__cmt-box + .bnfOther__cmt-box {
    margin-top: 3.2rem;
  }

  #main-top .bnfOther__cmt-box--avt {
    position: relative;
    z-index: 2;
    width: 19rem;
    border-radius: 50%;
    border: 1rem solid #fff;
  }

  #main-top .bnfOther__cmt-box--content {
    width: 100%;
    padding: 3.6rem 1rem 4.4rem;
    margin-top: -4rem;
    background-color: #fff;
    border-radius: 2rem;
  }

  #main-top .bnfOther__cmt-box--content > p {
    font-size: 3rem;
    text-align: center;
    line-height: 1.74;
  }

  #main-top .bnfOther__cmt-box--content::before,
  #main-top .bnfOther__cmt-box--content::after {
    width: 11.4rem;
    height: 10.4rem;
  }

  #main-top .bnfOther__cmt-box--content::before {
    left: -4rem;
    top: -4rem;
  }

  #main-top .bnfOther__cmt-box--content::after {
    right: -4rem;
    bottom: -4rem;
  }
}

#main-top .faq {
  position: relative;
  z-index: 3;
}

#main-top .faq-bg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: calc(50vw + 55.2rem + 27rem);
  background-color: rgb(27, 145, 49);
  border-radius: 0 28rem 0 0;
  z-index: 0;
  overflow: hidden;
}

#main-top .faq-inner {
  padding: 13rem 0 11rem;
}

#main-top .faq-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

#main-top .faq-title__en {
  font-size: 6rem;
  font-family: din-2014, sans-serif;
  color: rgb(255, 255, 255);
  line-height: 0.783;
  text-align: center;
}

#main-top .faq-title__ja {
  font-size: 3.6rem;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  text-align: center;
  margin-top: 2.5rem;
}

#main-top .faq-content {
  margin-top: 9.5rem;
}

#main-top .faq-content .accordion-item {
  background: #fff;
  border-radius: 2rem;
  margin-bottom: 3.5rem;
  overflow: hidden;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  padding: 0 4.4rem 0 3.5rem;
}

#main-top .faq-content .accordion-header {
  padding: 3rem 0;
  cursor: pointer;
  position: relative;
  font-size: 3rem;
  color: rgb(27, 145, 49);
  font-weight: bold;
  line-height: 1.5;
}

#main-top .faq-content .accordion-header > .label {
  font-family: din-2014, sans-serif;
  font-size: 3.5rem;
  color: rgb(27, 145, 49);
  line-height: 1;
  margin-right: 1rem;
  font-weight: 700;
}

#main-top .faq-content .accordion-header::before {
  content: "";
  position: absolute;
  width: 3rem;
  height: 0.3rem;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  background-color: rgb(192, 192, 192);
}

#main-top .faq-content .accordion-header::after {
  content: "";
  position: absolute;
  height: 3rem;
  width: 0.3rem;
  right: 1.3rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, -webkit-transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transition: opacity 0.3s ease, transform 0.3s ease,
    -webkit-transform 0.3s ease;
  background-color: rgb(192, 192, 192);
}

#main-top .faq-content .accordion-header.active::after {
  opacity: 0;
  -webkit-transform: translateY(-50%) rotate(90deg);
  transform: translateY(-50%) rotate(90deg);
}

#main-top .faq-content .accordion-content {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height 0.3s ease, padding 0.3s ease;
  transition: max-height 0.3s ease, padding 0.3s ease;
  position: relative;
}

#main-top .faq-content .accordion-content::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: rgb(192, 192, 192);
  top: 1px;
  left: 0;
  z-index: 1;
}

#main-top .faq-content .accordion-content > p {
  padding: 2rem 8rem 3rem 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#main-top .faq-content .accordion-content > p > .text {
  font-size: 2.4rem;
  font-weight: 400;
  color: rgb(61, 61, 61);
  line-height: 1.667;
}

#main-top .faq-content .accordion-content > p > .label {
  font-family: din-2014, sans-serif;
  font-size: 3.5rem;
  color: #3d3d3d;
  line-height: 1;
  margin-right: 2rem;
  font-weight: 700;
}

#main-top .faq-content .accordion-content > p .note {
  font-size: 1.6rem;
}

@media screen and (max-width: 750px) {
  #main-top .faq-bg {
    width: 100%;
    border-radius: 0 14rem 0 0;
  }

  #main-top .faq-inner {
    padding: 9.2rem 0 7.5rem;
  }

  #main-top .faq-title__en {
    font-size: 6.3rem;
  }

  #main-top .faq-title__ja {
    margin-top: 1.5rem;
  }

  #main-top .faq-content {
    margin-top: 6.5rem;
  }

  #main-top .faq-content .accordion-item {
    padding: 0 2.4rem 0 2.5rem;
  }

  #main-top .faq-content .accordion-header {
    padding: 2.8rem 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 3.5rem;
    line-height: 1.38;
  }

  #main-top .faq-content .accordion-header > .label {
    font-size: 4.6rem;
  }

  #main-top .faq-content .accordion-header::before {
    height: 0.5rem;
    top: 36%;
  }

  #main-top .faq-content .accordion-header::after {
    width: 0.5rem;
    right: 1.2rem;
    top: 36%;
  }

  #main-top .faq-content .accordion-content > p {
    padding: 2rem 4rem 3.5rem 2.8rem;
  }

  #main-top .faq-content .accordion-content > p > .text {
    font-size: 3rem;
    line-height: 1.3333333333;
  }

  #main-top .faq-content .accordion-content > p > .label {
    font-size: 4.6rem;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
  }

  #main-top .faq-content .accordion-content > p .note {
    font-size: 2rem;
    line-height: 1.5;
  }
}

@media screen and (max-width: 750px) {
  .floating {
    position: fixed;
    width: 100%;
    left: 0;
    bottom: 0;
    top: auto;
    background-color: rgba(255, 255, 255, 0.9);
    z-index: 99;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }

  .floating.show {
    opacity: 1;
    pointer-events: auto;
  }

  .floating-inner {
    padding: 2rem 1rem;
  }

  .floating-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 3rem;
    width: 90%;
    border-radius: 6.5rem;
    min-height: 13.2rem;
    padding: 2rem 5rem;
    -webkit-box-shadow: 0px 0.6rem 0px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0.6rem 0px 0px rgba(0, 0, 0, 0.2);
    background-color: rgb(255, 219, 0);
    margin: 0 auto;
  }

  .floating-btn--text {
    font-size: 4.6rem;
    -webkit-box-flex: 1;
    -ms-flex: 1 auto;
    flex: 1 auto;
    text-align: center;
    font-weight: bold;
    color: #2e2e2e;
    line-height: 1.2;
  }

  .floating-btn--icon {
    width: 5rem;
    height: 1.9rem;
    position: relative;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  }

  .floating-btn--icon::before {
    content: "";
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    pointer-events: none;
    width: 100%;
    height: 100%;
    background-image: url(../img/arrow_btn.png);
    left: 0;
    top: 0;
    z-index: 1;
  }
}

@-webkit-keyframes animate {
  0% {
    opacity: 0;
    -webkit-transform: rotate(135deg) translateY(1rem);
    transform: rotate(135deg) translateY(1rem);
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: rotate(135deg) translateY(1rem);
    transform: rotate(135deg) translateY(1rem);
  }
}

@keyframes animate {
  0% {
    opacity: 0;
    -webkit-transform: rotate(135deg) translateY(1rem);
    transform: rotate(135deg) translateY(1rem);
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: rotate(135deg) translateY(1rem);
    transform: rotate(135deg) translateY(1rem);
  }
}

@-webkit-keyframes arrow {
  50% {
    -webkit-transform: translateY(-1.5rem) translateX(-50%);
    transform: translateY(-1.5rem) translateX(-50%);
  }
}

@keyframes arrow {
  50% {
    -webkit-transform: translateY(-1.5rem) translateX(-50%);
    transform: translateY(-1.5rem) translateX(-50%);
  }
}



/* form */
.space{
  height: 8rem;
  background-color: #f2f2f2;
  display: none;
}

#wrapper.formConfirm .space{
  display: block;
}

.form {
  position: relative;
  background-color: #f2f2f2;
  padding: 8rem 0 10rem;
}

.form-content {
  max-width: 114rem;
  margin: 0 auto;
  border-radius: 3rem;
  background-color: #fff;
  padding: 6rem 11.5rem 9rem;
}

.form-title {
  text-align: center;
  font-size: 4.5rem;
  color: #333333;
  position: relative;
  margin-bottom: 5rem;
  padding-bottom: 0.5rem;
}

.form-titleSub {
  font-size: 2.2rem;
  margin-bottom: 3rem;
  line-height: 1.6;
  display: none;
}

.form-titleSub .txt_red {
  color: red;
  font-weight: bold;
}

.c-form__group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 3.5rem;
}

.c-form__control-wrap {
  width: 100%;
  display: block;
}

.c-form__tit {
  font-family: "Inter", sans-serif;
  color: #252d3e;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: calc(30 / 16);
  display: flex;
  align-items: center;
  gap: 2rem;
}

.c-form__control {
  display: block;
}

.c-form__tit .required {
  min-width: 3.8rem;
  min-height: 2.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4rem;
  background-color: rgb(210, 61, 61);
  letter-spacing: 0;
  color: #fff;
  font-size: 2rem;
  line-height: 1.4;
  font-weight: bold;
  padding: 0rem 1.5rem 0.2rem;
}

.c-form__tit .required.--no {
  background-color: rgb(10, 133, 202);
}

.c-form__group .wpcf7-form-control-wrap {
  width: 100%;
  position: relative;
}

.c-form__control__input,
.c-form__control textarea {
  background-color: #fff;
  font-size: 2.2rem;
  line-height: 1.5;
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  width: 100%;
  color: #000 !important;
  font-weight: 400;
  line-height: calc(30 / 16);
  min-height: 7rem;
  border-width: 1px;
  border-color: #e1e1e1;
  border-style: solid;
}

.c-form .error-message {
  color: red;
  font-size: 1.8rem;
}

.c-form__control__input::placeholder,
.c-form__control textarea::placeholder {
  font-size: 2.2rem;
  color: #a8a8a8;
  line-height: 1;
  font-weight: 400;
}

.c-form .txt_note {
  font-family: "Inter", sans-serif;
  font-size: 1.5rem;
  color: #000;
  font-weight: 400;
}

.c-form__control textarea {
  height: 38rem;
}
.c-form .c-form__check {
  display: inline-block;
  padding-left: 3.5rem;
  position: relative;
  font-size: 2rem;
  font-weight: bold;
  line-height: 2.05;
  color: #000;
  margin-top: 1rem;
}

.c-form .c-form__check input {
  position: absolute;
  top: -4.3rem;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.c-form .c-form__check--checkmark {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0;
  height: 2.6rem;
  width: 2.6rem;
  border-radius: 0.2rem;
  background-color: #fff;
  border: 1px solid #b5b5b5;
  cursor: pointer;
}

.c-form__check input:checked ~ .c-form__check--checkmark:after {
  border: solid #e60313;
  left: 1rem;
  top: -1rem;
  width: 1.2rem;
  height: 2.8rem;
  border-width: 0 0.3rem 0.3rem 0;
  -webkit-transform: rotate(40deg);
  transform: rotate(40deg);
  content: "";
  position: absolute;
}

.c-form .c-form__check > a {
  position: relative;
  color: #000;
}
.c-form .submit-area {
  text-align: center;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3rem;
  margin-top: 6rem;
}

.c-form input.submit,
.c-form .btnSubmit {
  font-family: "Inter", sans-serif;
  position: relative;
  width: 100%;
  cursor: pointer;
  background-color: rgb(27, 145, 49);
  height: 8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-color: rgb(27, 145, 49);
  border-width: 0.3rem;
  border-style: solid;
  font-size: 3rem;
  color: #fff;
  font-weight: bold;
  border-radius: 10rem;
  transition: all 0.3s ease;
}

.c-form .btn-submit_send {
  width: 100%;
}

.c-form .btnSubmit.btn-submit_back {
  background-color: #999999;
  border-color: #999999;
  color: #fff;
}

@media screen and (min-width: 751px) {
  .c-form input.submit:hover,
  .c-form .btnSubmit:hover {
    background-color: #fff;
    color: rgb(27, 145, 49);
  }

  .c-form .btnSubmit.btn-submit_back:hover {
    background-color: #fff;
    color: #000;
  }
}

.wrapper.formConfirm .d-hide {
  display: none;
}

.c-form.confirm .c-form__control__input,
.c-form.confirm .c-form__control textarea {
  display: none;
}

.c-form.confirm .c-form-confirm {
  font-size: 2rem;
  line-height: 1.5;
  display: flex;
  align-items: center;
  width: 100%;
  color: #000 !important;
  font-weight: 400;
  padding: 0rem 0 1rem;
  border-bottom: 1px solid rgb(181, 181, 181);
}

.wrapper.formConfirm .form-titleSub {
  display: block;
}

.c-form.confirm .c-form__note,
.c-form.confirm .c-form__tit .required {
  display: none;
}

.c-form.confirm .form-title {
  margin-bottom: 7rem;
}

@media screen and (max-width: 750px) {
  #form.sec-confirm{
  padding: 18rem 0 10rem;
}
  .form-content {
    max-width: calc(100% - 6rem);
    padding: 6rem 4rem 9rem;
  }

  .c-form__tit {
    font-size: 3rem;
  }

  .form-titleSub{
    font-size: 2.8rem;
  }

  .c-form.confirm .c-form-confirm{
    font-size: 2.8rem;
  }

  .c-form__control__input,
  .c-form__control textarea {
    min-height: 7.5rem;
    font-size: 2.8rem;
  }

  .c-form__control__input::placeholder {
    font-size: 2.8rem;
  }
}
