/*!************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/postcss-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./_src/css/style.scss ***!
  \************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* box sizing
-------------------------------------*/
*, ::before, ::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* general params
-------------------------------------*/
h1, h2, h3, h4, h5, h6,
div, p, pre, ul, ol, dl, dt, dd,
address, form, blockquote {
  margin: 0;
  padding: 0; /* margin&padding reset */
  font-style: normal;
  font-weight: normal;
}

hr, .areaAnchor, .anchor {
  display: none;
}

li {
  list-style: none;
}

/* word break
-------------------------------------*/
p {
  word-break: normal;
}

i {
  font-style: normal;
}

/*  2: form setting
-------------------------------------*/
option {
  padding-right: 10px;
}

input, select {
  vertical-align: middle;
}

/*-------------------------------------------> Viewport size */
/*-------------------------------------------> Design comp size */
/*-------------------------------------------> Media queries */
/*-------------------------------------------> SP : contents width */
/*-------------------------------------------> PC : contents width */
/*-------------------------------------------> web font */
/*-------------------------------------------> animation */
/* easeInOutExpo */
@-webkit-keyframes animate-panel {
  0% {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
  }
  49% {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  50% {
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  100% {
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
  }
}
@keyframes animate-panel {
  0% {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
  }
  49% {
    -webkit-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  50% {
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  100% {
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
  }
}
@-webkit-keyframes animate-content {
  0% {
    visibility: hidden;
  }
  49% {
    visibility: hidden;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
  }
}
@keyframes animate-content {
  0% {
    visibility: hidden;
  }
  49% {
    visibility: hidden;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
  }
}
@-webkit-keyframes stickyShow {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: none;
            transform: none;
  }
}
@keyframes stickyShow {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: none;
            transform: none;
  }
}
@-webkit-keyframes stickyHide {
  0% {
    -webkit-transform: none;
            transform: none;
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@keyframes stickyHide {
  0% {
    -webkit-transform: none;
            transform: none;
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
/*-------------------------------------------> font size (rem) */
/*-------------------------------------------> font size (vw -> rem) */
/*-------------------------------------------> fletter space */
/*-------------------------------------------> percentage (%) */
/*-------------------------------------------> vw ( width / height / padding / margin / position / and more ) */
/*-------------------------------------------> color */
/* Base color
-------------------------------------*/
/* Material color
-------------------------------------*/
/*-------------------------------------------> easing */
/*-------------------------------------------> Overwrite　logo size (local navi) */
.localnavi > p {
  margin-left: 30px;
}
@media screen and (max-width: 768px) {
  .localnavi > p {
    margin-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .index .localnavi {
    display: none;
  }
}
.localnavi > p a img {
  width: 190px;
}

.localnavi-box {
  width: calc(100% - 260px);
}

@media screen and (max-width: 1001px) {
  .localnavi-box {
    width: calc(100% - 15vw);
  }
}
/*-------------------------------------------> guide */
.guide {
  max-width: 1152px;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  margin: auto;
  pointer-events: none;
  border-left: 1px solid #ebebeb;
  border-right: 1px solid #ebebeb;
}
@media screen and (max-width: 1199px) {
  .guide {
    max-width: calc(100% - 20px);
  }
}
@media screen and (max-width: 768px) {
  .guide {
    max-width: calc(100% - 30px);
  }
}
.guide::before {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #ebebeb;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}
.guide::after {
  content: "";
  width: calc(100vw + 120px);
  height: 100%;
  min-height: 3896px;
  background: url(../../img/common/bg_content_pc.png) center top -460px/contain repeat-y;
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .guide::after {
    min-height: auto;
    background: url(../../img/common/bg_content_sp.png) center top/contain repeat-y;
  }
}

/*-------------------------------------------> body */
.content {
  color: #000;
  max-width: 1150px;
  font-size: 1.5rem;
  line-height: 1em;
  letter-spacing: 0em;
  font-family: "Noto Sans JP", "Original Yu Gothic", "Yu Gothic", YuGothic, "Hiragino Sans", sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
@media screen and (max-width: 768px) {
  .content {
    font-size: 1.4rem;
    line-height: 1em;
    letter-spacing: 0em;
    padding: 0 15px;
  }
}
.content figure {
  margin-bottom: 0;
}

.index .content {
  padding-bottom: 0;
}

.page-content {
  position: relative;
}

/*-------------------------------------------> link */
.content a {
  line-height: 1;
  outline: none;
  cursor: pointer;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.content a:hover {
  text-decoration: none;
}
.content a:focus {
  outline: none;
}

/*-------------------------------------------> image */
.content img {
  max-width: 100%;
  height: auto;
  line-height: 1;
}

/*-------------------------------------------> br */
.content br.sp {
  display: block;
}
@media screen and (min-width: 769px) {
  .content br.sp {
    display: none;
  }
}
.content br.pc {
  display: none;
}
@media screen and (min-width: 769px) {
  .content br.pc {
    display: block;
  }
}

/*-------------------------------------------> local navi */
.localnavi[data-page=page-features] .local-menu-features a {
  color: #3c7be3;
  -webkit-box-shadow: 0 -3px #3c7be3 inset;
          box-shadow: 0 -3px #3c7be3 inset;
}
.localnavi[data-page=page-price] .local-menu-price a {
  color: #3c7be3;
  -webkit-box-shadow: 0 -3px #3c7be3 inset;
          box-shadow: 0 -3px #3c7be3 inset;
}
.localnavi[data-page=page-scene] .local-menu-scene a {
  color: #3c7be3;
  -webkit-box-shadow: 0 -3px #3c7be3 inset;
          box-shadow: 0 -3px #3c7be3 inset;
}
.localnavi[data-page=page-introduce] .local-menu-introduce a {
  color: #3c7be3;
  -webkit-box-shadow: 0 -3px #3c7be3 inset;
          box-shadow: 0 -3px #3c7be3 inset;
}

/*-------------------------------------------> button */
.content .button-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 768px) {
  .content .button-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.content .button-wrap a {
  position: relative;
  display: block;
  width: 350px;
  text-align: center;
  padding: 27px 30px;
  border-radius: 37px;
  background-color: #3c7be3;
  margin: 0 17px;
}
@media screen and (max-width: 768px) {
  .content .button-wrap a {
    width: 220px;
    border-radius: 50px;
    margin: 0 auto;
    padding: 13px 0;
  }
  .content .button-wrap a:not(:last-child) {
    margin-bottom: 15px;
  }
}
@media (hover: hover) {
  .content .button-wrap a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .content .button-wrap a:hover {
    opacity: 0.7;
  }
}
.content .button-wrap a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5.5px 0 5.5px 6px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  right: 30px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .content .button-wrap a::after {
    right: 14px;
    border-width: 4.25px 0 4.25px 6px;
  }
}
.content .button-wrap a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1em;
  letter-spacing: 0.01em;
  display: inline-block;
  padding-bottom: 2px;
}
@media screen and (max-width: 768px) {
  .content .button-wrap a span {
    font-size: 1.3rem;
    line-height: 1.5384615385em;
    letter-spacing: 0.01em;
  }
}
.content .button-wrap.button-border a {
  background-color: rgba(0, 0, 0, 0);
  border: 1px solid #4c4c4c;
  padding: 26px 30px;
  width: 320px;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-border a {
    width: 220px;
    padding: 13px 20px;
  }
}
.content .button-wrap.button-border a::after {
  border-color: transparent transparent transparent #4c4c4c;
}
.content .button-wrap.button-border a span {
  color: #4c4c4c;
}
.content .button-wrap.button-border.l-single a {
  width: 310px;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-border.l-single a {
    width: 220px;
  }
}
.content .button-wrap.button-modal a {
  padding: 14px 30px;
  width: 270px;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-modal a {
    padding: 8px 30px;
    width: 210px;
  }
}
.content .button-wrap.button-modal a::before {
  content: "";
  display: block;
  width: 1px;
  height: 13px;
  background-color: #fff;
  position: absolute;
  right: 36px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-modal a::before {
    right: 20px;
  }
}
.content .button-wrap.button-modal a::after {
  content: "";
  display: block;
  width: 13px;
  height: 1px;
  background-color: #fff;
  border: none;
}
.content .button-wrap.button-modal a span {
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-modal a span {
    font-size: 1.3rem;
  }
}
.content .button-wrap.button-small {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.content .button-wrap.button-small a {
  width: 162px;
  padding: 14px 10px;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-small a {
    margin: 0 auto;
    width: 210px;
    padding: 10px;
  }
}
.content .button-wrap.button-small a::after {
  right: 15px;
  border-width: 4px 0 4px 5px;
}
.content .button-wrap.button-small span {
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .content .button-wrap.button-small span {
    font-size: 1.3rem;
  }
}

.content .hero-button a {
  text-align: center;
  position: relative;
  display: block;
  background-color: #3c7be3;
  padding: 12px 10px;
  width: 260px;
  border-radius: 20px;
}
@media screen and (max-width: 768px) {
  .content .hero-button a {
    display: inline-block;
    width: auto;
    padding: 12px 30px 12px 18px;
    border-radius: 20px;
  }
}
@media (hover: hover) {
  .content .hero-button a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .content .hero-button a:hover {
    opacity: 0.7;
  }
}
.content .hero-button a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5.5px 0 5.5px 6px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  right: 16px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .content .hero-button a::after {
    right: 14px;
    border-width: 4.25px 0 4.25px 6px;
  }
}
.content .hero-button a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.0666666667em;
  letter-spacing: 0.01em;
  display: inline-block;
  padding-bottom: 2px;
}
@media screen and (max-width: 768px) {
  .content .hero-button a span {
    font-size: 1.1rem;
    line-height: 1em;
    letter-spacing: 0em;
    padding-bottom: 2px;
  }
}

/*-------------------------------------------> modal */
.modal {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 1001;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
  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;
}
@media screen and (min-width: 769px) {
  .modal {
    padding: 90px 40px 40px;
  }
}
.modal-bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.modal-content {
  position: relative;
  width: 87.4666666667%;
}
@media screen and (min-width: 769px) {
  .modal-content {
    width: 100%;
    max-width: 950px;
  }
}
.modal-content-close {
  width: 35px;
  height: 35px;
  position: absolute;
  right: 0;
  top: -40px;
}
@media screen and (min-width: 769px) {
  .modal-content-close {
    width: 50px;
    height: 50px;
    top: -58px;
    right: 0px;
  }
}
@media (hover: hover) {
  .modal-content-close {
    cursor: pointer;
  }
}
.modal-content-close i {
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}
.modal-content-close i:nth-child(1) {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.modal-content-close i:nth-child(2) {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.modal-content-block {
  position: relative;
  padding: 56.75% 0 0;
  width: 100%;
  overflow: hidden;
  background-color: #000;
}
.modal-content-block iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.modal-content-block video {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

/*-------------------------------------------> PAGE WRAPPER */
/*-------------------------------------------> PAGE HEADER */
.hero.l-page-header {
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .hero.l-page-header {
    padding: 26px 15px 33px;
  }
}
.hero.l-page-header .section-inner {
  width: 100%;
  height: 350px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -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;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .hero.l-page-header .section-inner {
    height: auto;
  }
}
.hero.l-page-header h1 {
  font-weight: 700;
  font-size: 4rem;
  line-height: 1em;
  letter-spacing: 0em;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .hero.l-page-header h1 {
    font-size: 2.7rem;
    line-height: 1.4814814815em;
    letter-spacing: 0em;
    margin-bottom: 8px;
  }
}
.hero.l-page-header p {
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 1.8823529412em;
  letter-spacing: 0.05em;
  margin-bottom: 28px;
}
@media screen and (max-width: 768px) {
  .hero.l-page-header p {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0.05em;
    margin-bottom: 14px;
  }
}

.--module_heroContent {
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .--module_heroContent {
    padding: 26px 15px 33px;
  }
}

.--module_sectionContent {
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .--module_sectionContent {
    padding: 0;
  }
}

.--module_text01 {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .--module_text01 {
    font-size: 12px;
  }
}

.--module_text02 {
  font-size: 20px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .--module_text02 {
    font-size: 14px;
  }
}

.--module_tag01 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
}
.--module_tag01 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .--module_tag01 {
    font-size: 10px;
  }
}

.--module_tag02 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.03em;
}
.--module_tag02 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .--module_tag02 {
    font-size: 10px;
  }
}

.--module_lead01 {
  font-size: 18px;
  line-height: 1.89;
}
@media screen and (max-width: 768px) {
  .--module_lead01 {
    font-size: 13px;
    line-height: 1.846;
  }
}

.--module_head01 {
  font-size: 36px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .--module_head01 {
    font-size: 20px;
  }
}
.--module_head01.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}

.--module_head02 {
  font-size: 28px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .--module_head02 {
    font-size: 16px;
  }
}
.--module_head02.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}

.--module_head03 {
  font-size: 20px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .--module_head03 {
    font-size: 14px;
  }
}

.--module_head04 {
  display: inline-block;
  font-size: 18px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
  color: #6bcbd8;
  border-bottom: 2px solid #6bcbd8;
}
.--module_head04 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .--module_head04 {
    font-size: 10px;
  }
}

.--module_head05 {
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}

.--module_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;
  background-color: #000;
  color: #fff;
  min-width: 300px;
  max-width: 320px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
}
.--module_btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.--module_headingBg {
  color: #fff;
  text-align: center;
  height: 184px;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #4b4346;
  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;
}
@media screen and (max-width: 768px) {
  .--module_headingBg {
    height: 127px;
  }
}
.--module_headingBg .--module_head01 {
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .--module_headingBg .--module_head01 {
    margin-top: 4px;
  }
}

/*
 *  Remodal - v1.1.1
 *  Responsive, lightweight, fast, synchronized with CSS animations, fully customizable modal window plugin with declarative configuration and hash tracking.
 *  http://vodkabears.github.io/remodal/
 *
 *  Made by Ilya Makarov
 *  Under MIT License
 */
/* ==========================================================================
   Remodal's necessary styles
   ========================================================================== */
/* Hide scroll bar */
html.remodal-is-locked {
  overflow: hidden;
  -ms-touch-action: none;
  touch-action: none;
}

/* Anti FOUC */
.remodal,
[data-remodal-id] {
  display: none;
}

/* Necessary styles of the overlay */
.remodal-overlay {
  position: fixed;
  z-index: 9999;
  top: -5000px;
  right: -5000px;
  bottom: -5000px;
  left: -5000px;
  display: none;
}

/* Necessary styles of the wrapper */
.remodal-wrapper {
  position: fixed;
  z-index: 10000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: none;
  overflow: auto;
  text-align: center;
  -webkit-overflow-scrolling: touch;
}
.remodal-wrapper:after {
  display: inline-block;
  height: 100%;
  margin-left: -0.05em;
  content: "";
}

/* Fix iPad, iPhone glitches */
.remodal-overlay,
.remodal-wrapper {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Necessary styles of the modal dialog */
.remodal {
  position: relative;
  outline: none;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

.remodal-is-initialized {
  /* Disable Anti-FOUC */
  display: inline-block;
}

/*
 *  Remodal - v1.1.1
 *  Responsive, lightweight, fast, synchronized with CSS animations, fully customizable modal window plugin with declarative configuration and hash tracking.
 *  http://vodkabears.github.io/remodal/
 *
 *  Made by Ilya Makarov
 *  Under MIT License
 */
/* ==========================================================================
   Remodal's default mobile first theme
   ========================================================================== */
/* Default theme styles for the background */
.remodal-bg.remodal-is-opening, .remodal-bg.remodal-is-opened {
  -webkit-filter: blur(3px);
  filter: blur(3px);
}

/* Default theme styles of the overlay */
.remodal-overlay {
  background: rgba(43, 46, 56, 0.9);
}
.remodal-overlay.remodal-is-opening, .remodal-overlay.remodal-is-closing {
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
.remodal-overlay.remodal-is-opening {
  -webkit-animation-name: remodal-overlay-opening-keyframes;
  animation-name: remodal-overlay-opening-keyframes;
}
.remodal-overlay.remodal-is-closing {
  -webkit-animation-name: remodal-overlay-closing-keyframes;
  animation-name: remodal-overlay-closing-keyframes;
}

/* Default theme styles of the wrapper */
.remodal-wrapper {
  padding: 10px 10px 0;
}

/* Default theme styles of the modal dialog */
.remodal {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  margin-bottom: 10px;
  padding: 35px;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  color: #2b2e38;
  background: #fff;
  vertical-align: middle;
}
.remodal.remodal-is-opening, .remodal.remodal-is-closing {
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
.remodal.remodal-is-opening {
  -webkit-animation-name: remodal-opening-keyframes;
  animation-name: remodal-opening-keyframes;
}
.remodal.remodal-is-closing {
  -webkit-animation-name: remodal-closing-keyframes;
  animation-name: remodal-closing-keyframes;
}

/* Vertical align of the modal dialog */
.remodal-wrapper:after {
  vertical-align: middle;
}

/* Close button */
.remodal-close {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  overflow: visible;
  width: 35px;
  height: 35px;
  margin: 0;
  padding: 0;
  cursor: pointer;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
  text-decoration: none;
  color: #95979c;
  border: 0;
  outline: 0;
  background: transparent;
}
.remodal-close:hover, .remodal-close:focus {
  color: #2b2e38;
}
.remodal-close:before {
  font-family: Arial, "Helvetica CY", "Nimbus Sans L", sans-serif !important;
  font-size: 25px;
  line-height: 35px;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 35px;
  content: "×";
  text-align: center;
}

/* Dialog buttons */
.remodal-confirm,
.remodal-cancel {
  font: inherit;
  display: inline-block;
  overflow: visible;
  min-width: 110px;
  margin: 0;
  padding: 12px 0;
  cursor: pointer;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  border: 0;
  outline: 0;
}

.remodal-confirm {
  color: #fff;
  background: #81c784;
}
.remodal-confirm:hover, .remodal-confirm:focus {
  background: #66bb6a;
}

.remodal-cancel {
  color: #fff;
  background: #e57373;
}
.remodal-cancel:hover, .remodal-cancel:focus {
  background: #ef5350;
}

/* Remove inner padding and border in Firefox 4+ for the button tag. */
.remodal-confirm::-moz-focus-inner,
.remodal-cancel::-moz-focus-inner,
.remodal-close::-moz-focus-inner {
  padding: 0;
  border: 0;
}

/* Keyframes
   ========================================================================== */
@-webkit-keyframes remodal-opening-keyframes {
  from {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 0;
  }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes remodal-opening-keyframes {
  from {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 0;
  }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@-webkit-keyframes remodal-closing-keyframes {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    opacity: 0;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes remodal-closing-keyframes {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    opacity: 0;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@-webkit-keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes remodal-overlay-opening-keyframes {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes remodal-overlay-closing-keyframes {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
/* Media queries
   ========================================================================== */
@media only screen and (min-width: 641px) {
  .remodal {
    max-width: 1200px;
  }
}
/* IE8
   ========================================================================== */
.lt-ie9 .remodal-overlay {
  background: #2b2e38;
}
.lt-ie9 .remodal {
  width: 700px;
}

.index {
  padding-bottom: 0;
}
.index .hero .section-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 64px 0 70px;
  position: relative;
  height: 650px;
}
@media screen and (max-width: 1000px) {
  .index .hero .section-inner {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 768px) {
  .index .hero .section-inner {
    height: auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 30px 0 18px;
  }
}
.index .hero-text {
  text-align: center;
  margin: 60px 0 0 10px;
}
@media screen and (max-width: 768px) {
  .index .hero-text {
    margin: 0 auto;
    width: 100%;
  }
}
.index .hero-text .heading {
  display: inline-block;
  font-size: 2.1rem;
  line-height: 2em;
  letter-spacing: 0.04em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: 700;
  border-bottom: 3px solid #000;
  padding: 0 5px 5px;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .index .hero-text .heading {
    font-size: 1.45rem;
    letter-spacing: 0.02em;
    padding: 0 0 5px;
    border-width: 2px;
  }
}
.index .hero-text .subheading {
  font-size: 1.8rem;
  font-weight: 700;
  margin-top: 23px;
}
@media screen and (max-width: 768px) {
  .index .hero-text .subheading {
    font-size: 1.45rem;
    margin-top: 10px;
  }
}
.index .hero-text .logo {
  margin: 28px 0 0 -4px;
  width: 486px;
}
@media screen and (max-width: 768px) {
  .index .hero-text .logo {
    width: 100%;
    margin: 15px auto 0;
  }
}
.index .hero-text .share {
  margin-top: 46px;
}
@media screen and (max-width: 768px) {
  .index .hero-text .share {
    width: 100%;
    margin: 15px auto 0;
  }
}
.index .hero-note {
  position: absolute;
  left: 36px;
  bottom: 72px;
  text-align: left;
  font-size: 1rem;
  line-height: 2rem;
}
@media screen and (max-width: 1000px) {
  .index .hero-note {
    bottom: 20px;
  }
}
@media screen and (max-width: 768px) {
  .index .hero-note {
    position: static;
    line-height: 1.5rem;
  }
}
.index .hero-image {
  margin-top: 40px;
  min-width: 60%;
}
@media screen and (max-width: 768px) {
  .index .hero-image {
    -webkit-box-ordinal-group: 1;
        -ms-flex-order: 0;
            order: 0;
    margin-top: 18px;
  }
}
/* 共通CTA */
.index .info {
  position: relative;
}
.index .info::before {
  content: "";
  background-color: #3C7BE3;
  width: 100vw;
  height: 100%;
  position: absolute;
  z-index: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.index .info .section-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  justify-content: center;
  flex-direction: column;
  position: relative;
  z-index: 1;
  height: 170px;
}
@media screen and (max-width: 768px) {
  .index .info .section-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
    padding: 19px 0 25px;
  }
}
.index .info .heading {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 4rem;
  white-space: nowrap;
  letter-spacing: 0.04em;
  color: #fff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .index .info .heading {
    text-align: center;
    font-size: 1.9rem;
    margin: 0 auto;
    line-height: 2.9rem;
  }
}
.index .info .heading::before,
.index .info .heading::after {
  position: relative;
  display: inline-block;
  content: "";
  background: #fff;
  width: 2px;
  height: 29px;
  margin: 0 0.8em;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .index .info .heading::before,
  .index .info .heading::after {
    content: none;
  }
}
.index .info .heading::before {
  transform: rotate(-45deg);
}
.index .info .heading::after {
  transform: rotate(45deg);
}
.index .info .button-wrap {
  margin-top: 15px;
  display: flex;
  gap: 20px;
}
@media screen and (max-width: 1057px) {
  .index .info .button-wrap {
    margin-top: 15px;
    gap: 10px;
  }
}
@media screen and (max-width: 768px) {
  .index .info .button-wrap {
    margin: 15px auto 0;
  }
}
.index .info .button-wrap a {
  width: 360px;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .index .info .button-wrap a {
    width: 220px;
    margin: 0 auto;
  }
}
.index .info .button-wrap a span {
  font-size: 1.6rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .index .info .button-wrap a span {
    font-size: 1.3rem;
  }
}
.index .info .button-wrap .red-btn {
  background-color: #b40200;
}
.index .info .button-wrap .white-btn {
  background-color: #fff;
}
.index .info .button-wrap .red-btn::after,
.index .info .button-wrap .white-btn::after {
  content: none;
}
.index .info .button-wrap .white-btn span {
  color: #3C7BE3;
}
.index .info .img {
  position: absolute;
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .index .info .img {
    display: none;
  }
}
.index .info.type01 .img {
  width: 175px;
  left: calc(50% + 390px);
}
.index .info.type02 .img {
  width: 175px;
  left: calc(50% + 230px);
}
.index .info.type03 .img {
  width: 165px;
  right: calc(50% + 230px);
}

.index .lineup {
  background-color: #EBF2FC;
  margin: 0 calc(50% - 50vw);
  overflow: hidden;
  padding: 80px 20px;
}
@media screen and (max-width: 768px) {
  .index .lineup {
    padding: 30px 0;
  }
}
.index .lineup .heading {
  text-align: center;
  font-size: 3.6rem;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 0;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .index .lineup .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .lineup .heading span {
  color: #3c7be3;
  margin-left: -1px;
  letter-spacing: -0.02;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .index .lineup .heading span {
    font-size: 2rem;
    border-width: 2px;
  }
}
.index .lineup .lineup-list {
  max-width: 1150px;
  margin: 68px auto 0;
  display: flex;
  gap: 11px;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-list {
    flex-direction: column;
    margin-top: 20px;
    padding: 0 15px;
    gap: 20px;
  }
}
.index .lineup .lineup-item {
  background-color: #fff;
  display: block;
  position: relative;
  width: calc((100% - 22px) / 3);
  padding: 30px 35px;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-item {
    width: 100%;
    padding: 30px;
  }
}
.index .lineup .lineup-item-tag {
  display: flex;
  gap: 8px;
}
.index .lineup .lineup-item-tag span {
  background-color: #EDF4FD;
  color: #3C7BE3;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  padding: 5px 10px;
}
.index .lineup .lineup-item-tag span.pink {
  background-color: #FCEBF2;
  color: #E33C82;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-item-tag span {
    font-size: 12px;
  }
}
.index .lineup .lineup-item-logo {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-item-logo {
    margin-top: 10px;
    text-align: center;
  }
}
.index .lineup .lineup-item-text {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0.01em;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-item-text {
    font-size: 13px;
    margin-top: 10px;
  }
}
.index .lineup .lineup-item-btn {
  position: relative;
  display: block;
  font-size: 1.5rem;
  color: #fff;
  background: #3c7be3;
  font-weight: bold;
  line-height: 1em;
  letter-spacing: 0.01em;
  text-align: center;
  padding: 20px 10px;
  width: 100%;
  max-width: 205px;
  margin-left: auto;
  margin-right: auto;
  border-radius: 28px;
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .index .lineup .lineup-item-btn {
    max-width: 220px;
  }
}
.index .lineup .lineup-item-btn span {
  font-weight: bold;
}
.index .lineup .lineup-item-btn:hover {
  opacity: 0.7;
}
.index .lineup .button-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .index .lineup .button-wrap {
    margin-top: 31px;
  }
}
.index .lineup .button-wrap a {
  width: 421px;
}
@media screen and (max-width: 768px) {
  .index .lineup .button-wrap a {
    width: 290px;
  }
}
.index .lineup .movie {
  width: 730px;
  margin-top: 60px;
  margin-right: auto;
  margin-left: auto;
  padding-bottom: 70px;
  aspect-ratio: 4 / 3;
}
@media screen and (max-width: 768px) {
  .index .lineup .movie {
    width: 100%;
    margin-top: 20px;
    padding-bottom: 30px;
    padding-left: 15px;
    padding-right: 15px;
  }
}
.index .lineup .movie iframe {
  width: 100%;
  height: 100%;
  margin-right: auto;
  margin-left: auto;
  display: inline-block;
}
.index .company {
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #fff;
  padding: 80px 20px;
}
@media screen and (max-width: 768px) {
  .index .company {
    margin: 0 -15px 0;
    padding: 30px 5px;
  }
}
.index .company .heading {
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .company .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .company .logo-list {
  max-width: 1000px;
  margin: 60px auto 0;
  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;
}
@media screen and (max-width: 768px) {
  .index .company .logo-list {
    margin-top: 20px;
    padding: 0 10px;
  }
}
.index .company .logo-list .item {
  width: 198px;
  border: 1px solid #e5e5e5;
}
@media screen and (max-width: 768px) {
  .index .company .logo-list .item {
    width: calc(33% - 2px);
    background-color: #fff;
    padding: 2px 0;
  }
}

.index .scene {
  background-color: #fff;
  margin: 0 calc(50% - 50vw);
  overflow: hidden;
}
.index .scene .section-inner {
  max-width: 1150px;
  margin: 80px auto 80px;
  background-color: #fff;
  padding: 80px 60px 50px;
  -webkit-box-shadow: 0 0 15px #ebebeb;
  box-shadow: 0 0 15px #ebebeb;
}
@media screen and (max-width: 768px) {
  .index .scene .section-inner {
    padding: 30px 15px;
    margin-top: 30px;
    margin-bottom: 30px;
  }
}
.index .scene .heading {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .index .scene .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .scene-heading {
  font-size: 2.8rem;
  font-weight: bold;
  margin-top: 60px;
  line-height: normal;
}
@media screen and (max-width: 768px) {
  .index .scene-heading {
    font-size: 1.8rem;
    margin-top: 30px;
    line-height: 3rem;
  }
}
.index .scene .scene-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 70px;
  margin-left: -3.33%;
}
.index .scene .scene-heading + .scene-list {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 20px;
  }
  .index .scene .scene-heading + .scene-list {
    margin-top: 20px;
  }
}
.index .scene .scene-list .item {
  padding: 55px 18px 0px;
  width: 30%;
  margin-left: 3.33%;
  max-width: 305px;
  background-color: #ebf2fc;
  text-align: center;
  margin-bottom: 140px;
}
@media screen and (max-width: 1010px) {
  .index .scene .scene-list {
    margin-left: -2%;
  }
  .index .scene .scene-list .item {
    width: 48%;
    margin-left: 2%;
    max-width: none;
  }
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list {
    margin-left: 0;
  }
  .index .scene .scene-list .item {
    margin-bottom: 0;
    margin-left: 0;
  }
  .index .scene .scene-list .item + .item {
    margin-top: 15px;
  }
  .index .scene .scene-list .item:nth-child(2) {
    margin: 15px auto 0;
  }
  .index .scene .scene-list .item:nth-child(n+4) {
    margin: 15px auto 0;
  }
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list .item {
    width: 100%;
    padding: 25px 0 20px;
  }
}
.index .scene .scene-list .item .title {
  font-size: 2.1rem;
  font-weight: 700;
  color: #3c7be3;
  position: relative;
  padding-bottom: 23px;
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list .item .title {
    font-size: 1.6rem;
    padding-bottom: 15px;
  }
}
.index .scene .scene-list .item .title::after {
  content: "";
  width: 25px;
  height: 1px;
  background-color: #bbc0c7;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list .item .title::after {
    width: 12px;
  }
}
.index .scene .scene-list .item .desc {
  font-size: 1.6rem;
  line-height: 2.8rem;
  margin-top: 15px;
  margin-bottom: -45px;
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list .item .desc {
    font-size: 1.3rem;
    line-height: 2.3rem;
    margin-top: 7px;
    margin-bottom: 0;
  }
}
.index .scene .scene-list .item .image {
  position: relative;
  top: 75px;
}
@media screen and (max-width: 768px) {
  .index .scene .scene-list .item .image {
    top: 0px;
    margin-top: 5px;
    padding: 0 20px;
  }
}
.index .scene .scene-list .item .image img {
  width: 100%;
  height: auto;
}
.index .scene .button-wrap a {
  padding: 14px 30px;
  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;
}
.index .scene .button-wrap a span {
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  .index .scene .button-wrap a {
    padding: 8px 30px;
  }
  .index .scene .button-wrap a span {
    font-size: 1.3rem;
  }
}
.index .scene .button-wrap a::after {
  content: none;
}

.index .bnr {
  margin: 0 calc(50% - 50vw);
  overflow: hidden;
  background-color: #fff;
  padding: 80px 0;
}
@media screen and (max-width: 768px) {
  .index .bnr {
    padding: 30px 0;
  }
}
.index .bnr .bnr-list {
  max-width: 1150px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 940px) {
  .index .bnr .bnr-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 30px;
  }
}
.index .bnr .bnr-item {
  color: #000;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
  width: 47.8260869565%;
  margin-top: 3px;
}
@media screen and (max-width: 940px) {
  .index .bnr .bnr-item {
    width: 100%;
    max-width: 550px;
  }
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item {
    width: 100%;
    margin: 0 auto 10px;
  }
}
.index .bnr .bnr-item-text-wrap {
  position: absolute;
  top: 68px;
  left: 32px;
  -webkit-transition: opacity ease-in-out 0.3s;
  transition: opacity ease-in-out 0.3s;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-text-wrap {
    top: 40px;
    left: 22px;
  }
}
.index .bnr .bnr-item-text {
  font-size: 14px;
  letter-spacing: 0.01em;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-text {
    font-size: 10px;
    margin-bottom: 3px;
  }
}
.index .bnr .bnr-item-title {
  font-size: 27px;
  font-weight: bold;
  line-height: 1.2962962963;
  letter-spacing: 0.01em;
  margin-top: 14px;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-title {
    font-size: 17px;
    margin-top: 6px;
  }
}
.index .bnr .bnr-item-image {
  width: 100%;
}
.index .bnr .bnr-item-image:hover img {
  opacity: 0.7;
}
.index .bnr .bnr-item-image img {
  -webkit-transition: opacity ease-in-out 0.3s;
  transition: opacity ease-in-out 0.3s;
  width: 100%;
}
.index .bnr .bnr-item-wrap {
  padding: 30px 34px 50px;
  background-color: #FCFCFC;
  flex: 1;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-wrap {
    padding: 10px 20px 30px;
  }
}
.index .bnr .bnr-item-desc {
  left: 32px;
  font-size: 1.6rem;
  line-height: 2.9rem;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-desc {
    font-size: 12px;
    line-height: 1.7;
    margin-top: 0;
  }
}
.index .bnr .bnr-item-btn {
  -webkit-transition: opacity ease-in-out 0.3s;
  transition: opacity ease-in-out 0.3s;
  margin-top: 30px;
  display: inline-block;
}
.index .bnr .bnr-item-btn:hover {
  opacity: 0.7;
}
.index .bnr .bnr-item-btn span {
  color: #000;
  font-size: 15px;
  letter-spacing: -0.04em;
  font-weight: 500;
  width: 210px;
  height: 45px;
  padding-left: 50px;
  border: 1px solid #000;
  border-radius: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-btn span {
    font-size: 13px;
    width: 220px;
    height: 38px;
    padding: 4px 60px;
  }
}
.index .bnr .bnr-item-btn span::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #000;
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: all ease-in-out 0.3s;
  transition: all ease-in-out 0.3s;
}
@media screen and (max-width: 768px) {
  .index .bnr .bnr-item-btn span::before {
    right: 7px;
    border-color: transparent transparent transparent #000;
    border-width: 3.5px 0 3.5px 4px;
  }
}
.index .bnr-drsum {
  background-color: #F5F5F5;
  max-width: 1150px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  display: flex;
  gap: 20px;
  align-items: center;
  padding: 30px 65px 40px;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum {
    margin-top: 30px;
    flex-direction: column;
    padding: 20px;
  }
}
.index .bnr-drsum .img {
  width: 170px;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .img {
    width: 120px;
  }
}
.index .bnr-drsum .desc {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  width: fit-content;
}
.index .bnr-drsum .subtitle {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .subtitle {
    font-size: 1.6rem;
    margin-top: 10px;
  }
}
.index .bnr-drsum .title {
  color: #C40161;
  font-weight: bold;
  font-size: 3.5rem;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .title {
    font-size: 1.9rem;
  }
}
.index .bnr-drsum .text {
  line-height: 1.7;
  margin-top: 14px;
  font-size: 1.4rem;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .text {
    margin-top: 10px;
    font-size: 1.3rem;
  }
}
.index .bnr-drsum .text span {
  color: #C40161;
  font-weight: bold;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .text span {
    font-size: 1.4rem;
  }
}
.index .bnr-drsum .btn {
  position: relative;
  display: block;
  font-size: 1.6rem;
  color: #fff;
  background: #3c7be3;
  font-weight: bold;
  line-height: 1em;
  letter-spacing: 0.01em;
  text-align: center;
  padding: 10px 10px;
  width: 100%;
  max-width: 360px;
  margin-left: auto;
  margin-right: auto;
  border-radius: 50px;
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  margin-top: 30px;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .bnr-drsum .btn {
    max-width: 220px;
    font-size: 1.3rem;
  }
}
.index .bnr-drsum .btn:hover {
  opacity: 0.7;
}


.index .about {
  position: relative;
  padding: 80px 20px;
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .index .about {
    padding: 30px 15px;
  }
}
.index .about .heading {
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .about .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .about .about-lead {
  font-size: 2.4rem;
  color: #3C7BE3;
  font-weight: bold;
  margin-top: 60px;
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .about .about-lead {
    font-size: 1.6rem;
    margin-top: 20px;
    text-align: left;
  }
}
.index .about .about-txt {
  font-size: 1.6rem;
  margin-top: 40px;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .about .about-txt {
    font-size: 1.3rem;
    margin-top: 20px;
    text-align: left;
  }
}
.index .about .about-img-01 {
  margin-top: 50px;
  margin-right: auto;
  margin-left: auto;
  width: 100%;
  max-width: 440px;
}
@media screen and (max-width: 768px) {
  .index .about .about-img-01 {
    margin-top: 20px;
    max-width: 300px;
  }
}
.index .about .about-figure {
  position: relative;
  width: 100%;
  max-width: 930px;
  margin-right: auto;
  margin-left: auto;
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .index .about .about-figure {
    margin-top: 30px;
  }
}
.index .about .about-img-02 {
  position: absolute;
  inset: 0;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .index .about .about-img-02 {
    width: 50%;
    max-width: 230px;
  }
}
.index .about .about-list {
  display: flex;
  flex-wrap: wrap;
  gap: 70px 80px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .index .about .about-list {
    gap: 10px;
  }
}
.index .about .about-item {
  width: calc((100% - 80px) / 2);
  text-align: center;
  font-size: 2.2rem;
  line-height: 1.5;
  padding: 50px 10px;
}
@media screen and (max-width: 768px) {
  .index .about .about-item {
    width: calc((100% - 10px) / 2);
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .index .about .about-item:nth-child(1) {
    padding: 40px 10px 80px;
  }
  .index .about .about-item:nth-child(2) {
    padding: 40px 10px 80px;
  }
  .index .about .about-item:nth-child(3) {
    padding: 80px 10px 40px;
  }
  .index .about .about-item:nth-child(4) {
    padding: 80px 10px 40px;
  }
}
.index .about .about-item span {
  font-size: 2.4rem;
  font-weight: bold;
  display: block;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .index .about .about-item span {
    font-size: 1.5rem;
    margin-top: 10px;
  }
}
.index .about .about-item.pink {
  background-color: #FCEBF2;
}
.index .about .about-item.pink span {
  color: #E33C82;
}
.index .about .about-item.blue {
  background-color: #EBF2FC;
}
.index .about .about-item.blue span {
  color: #3C7BE3;
}

.index .features {
  position: relative;
  padding: 80px 20px;
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #EBF2FC;
}
@media screen and (max-width: 768px) {
  .index .features {
    padding: 30px 15px;
  }
}
.index .features .heading {
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .features .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .features .features-lead {
  margin-top: 40px;
  font-size: 1.6rem;
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .features .features-lead {
    margin-top: 20px;
    font-size: 1.4rem;
    text-align: left;
  }
}
.index .features .features-point {
  margin-top: 45px;
  max-width: 930px;
  margin-right: auto;
  margin-left: auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .index .features .features-point {
    margin-top: 20px;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}
.index .features .features-point .item {
  background-color: #fff;
  border-radius: 10px;
  position: relative;
  padding: 13px 17px 40px;
  display: flex;
  border: 2px solid #3C7BE3;
}
@media screen and (max-width: 768px) {
  .index .features .features-point .item {
    border-radius: 10px;
    padding: 15px;
    flex-direction: column;
    border: 1px solid #3C7BE3;
  }
}
.index .features .features-point .desc {
  flex: 1;
}
.index .features .features-point .label {
  font-size: 1.6rem;
  line-height: 1.6;
  font-weight: bold;
  color: #fff;
  background-color: #3C7BE3;
  display: inline-block;
  min-width: 57px;
  text-align: center;
  border-radius: 20px;
  padding: 0px 10px;
}
@media screen and (max-width: 768px) {
  .index .features .features-point .label {
    font-size: 1.3rem;
    min-width: 57px;
    padding: 0px 10px;
  }
}
.index .features .features-point .text {
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: bold;
  margin-left: 7px;
  margin-top: 28px;
}
@media screen and (max-width: 768px) {
  .index .features .features-point .text {
    font-size: 1.3rem;
    margin-left: 0px;
    margin-top: 10px;
  }
}
.index .features .features-point .img {
  width: 80px;
  margin-top: 27px;
}
@media screen and (max-width: 768px) {
  .index .features .features-point .img {
    width: 60px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
  }
}


.index .reason {
  position: relative;
  padding: 80px 20px;
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #EBF2FC;
}
@media screen and (max-width: 768px) {
  .index .reason {
    padding: 30px 15px;
  }
}
.index .reason .heading {
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .index .reason .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .reason .reason-wrap + .reason-wrap {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-wrap + .reason-wrap {
    margin-top: 30px;
  }
}
.index .reason .reason-lead {
  margin-top: 40px;
  font-size: 1.6rem;
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-lead {
    margin-top: 20px;
    font-size: 1.4rem;
    text-align: left;
  }
}
.index .reason .reason-point {
  margin-top: 45px;
  max-width: 930px;
  margin-right: auto;
  margin-left: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 42px;
}
@media screen and (max-width: 900px) {
  .index .reason .reason-point {
    gap: 30px;
  }
}
@media screen and (max-width: 768px) {
  .index .reason .reason-point {
    margin-top: 20px;
    grid-template-columns: 1fr;
    gap: 10px;
  }
}
.index .reason .reason-point .item {
  background-color: #fff;
  border-radius: 15px;
  position: relative;
  padding: 50px 70px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 900px) {
  .index .reason .reason-point .item {
    padding: 80px 30px;
  }
}
@media screen and (max-width: 768px) {
  .index .reason .reason-point .item {
    padding: 30px 20px 30px 85px;
  }
}
.index .reason .reason-point .img {
  width: 83px;
  position: absolute;
  left: 12px;
  top: 12px;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-point .img {
    width: 70px;
    left: 5px;
    top: 5px;
  }
}
.index .reason .reason-point .text {
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;
  color: #3C7BE3;
  line-height: 1.6;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-point .text {
    text-align: left;
    font-size: 1.6rem;
    width: 100%;
  }
}
.index .reason .reason-support {
  margin-top: 45px;
  max-width: 1150px;
  margin-right: auto;
  margin-left: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
}
@media screen and (max-width: 900px) {
  .index .reason .reason-support {
    gap: 30px;
  }
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support {
    margin-top: 20px;
    grid-template-columns: 1fr;
    gap: 10px;
  }
}
.index .reason .reason-support .item {
  background-color: #fff;
  border-radius: 10px;
  padding: 50px 70px;

  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0;
}
@media screen and (max-width: 900px) {
  .index .reason .reason-support .item {
    padding: 30px;
  }
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .item {
    padding: 30px;
  }
}
.index .reason .reason-support .title {
  font-size: 2.4rem;
  color: #3C7BE3;
  font-weight: bold;
  line-height: 1.6;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .title {
    font-size: 1.6rem;
  }
}
.index .reason .reason-support .img {
  margin-top: 10px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.index .reason .reason-support .img.img01 {
  max-width: 169px;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .img.img01 {
    max-width: 129px;
  }
}
.index .reason .reason-support .img.img02 {
  max-width: 271px;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .img.img02 {
    max-width: 231px;
  }
}
.index .reason .reason-support .text {
  font-size: 1.6rem;
  line-height: 1.6;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .text {
    font-size: 1.3rem;
    margin-top: 10px;
  }
}
.index .reason .reason-support .button {
  margin-top: 15px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .button {
    margin-top: 10px;
  }
}
.index .reason .reason-support .button a {
  font-size: 1.6rem;
  color: #fff;
  background-color: #3C7BE3;
  font-weight: bold;
  line-height: 1.6;
  padding: 13px 20px;
  border-radius: 50px;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .index .reason .reason-support .button a {
    font-size: 1.3rem;
  }
}


.index .task-ideal .index-belt-title {
  background-color: #4b4346;
  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;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 calc(50% - 50vw);
  padding: 50px calc(50vw - 50%) 50px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title {
    padding: 20px calc(50vw - 50%) 20px;
  }
}
.index .task-ideal .index-belt-title .index-entitle {
  font-size: 1.4rem;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
}
.index .task-ideal .index-belt-title .index-entitle else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title .index-entitle {
    font-size: 1rem;
  }
}
.index .task-ideal .index-belt-title .index-title {
  font-weight: 700;
  font-size: 3.2rem;
  line-height: 5.5rem;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title .index-title {
    font-size: 2.2rem;
    text-align: center;
    line-height: 3.2rem;
    margin-top: 5px;
  }
}
.index .task-ideal .task-ideal-current {
  position: relative;
  margin: 80px auto 0;
  max-width: 1050px;
  width: 100%;
  height: 330px;
  background: url(../../img/index/task_ideal_current_bg.png) center top/cover no-repeat;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current {
    margin-top: 40px;
    height: auto;
    padding-top: 147.5%;
    background: url(../../img/index/task_ideal_current_bg_sp.png) center top/cover no-repeat;
  }
}
.index .task-ideal .task-ideal-current .title {
  font-size: 2rem;
  color: #fff;
  background-color: #4b4346;
  width: 106px;
  height: 42px;
  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;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current .title {
    font-size: 1.2rem;
    width: 66px;
    height: 26px;
  }
}
.index .task-ideal .task-ideal-current p {
  font-size: 1.6rem;
  line-height: 2.8rem;
  position: absolute;
  white-space: nowrap;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current p {
    font-size: 1.3rem;
    line-height: 2rem;
  }
}
.index .task-ideal .task-ideal-current p.desc-01 {
  top: 55px;
  left: calc(50% - 192px);
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current p.desc-01 {
    top: 13.5%;
    left: calc(50% - 103px);
  }
}
.index .task-ideal .task-ideal-current p.desc-02 {
  top: 200px;
  left: calc(50% - 355px);
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current p.desc-02 {
    top: 37.5%;
    left: calc(50% - 65px);
  }
}
.index .task-ideal .task-ideal-current p.desc-03 {
  top: 177px;
  left: calc(50% + 150px);
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-current p.desc-03 {
    top: 61.5%;
    left: calc(50% - 110px);
  }
}
.index .task-ideal .task-ideal-arrow {
  width: 48px;
  margin: 30px auto 25px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-arrow {
    width: 33px;
    margin: 20px auto;
  }
}
.index .task-ideal .task-ideal-merit {
  border: 2px solid #3c7be3;
  max-width: 1050px;
  height: 522px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-merit {
    height: auto;
  }
}
.index .task-ideal .task-ideal-merit > .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;
  background-color: #3c7be3;
  color: #fff;
  font-size: 2rem;
  width: 170px;
  height: 44px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .task-ideal-merit > .title {
    font-size: 1.2rem;
    width: 97px;
    height: 26px;
  }
}
.index .task-ideal .merit-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list {
    -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;
    padding: 0 13px 25px;
    margin-top: 15px;
  }
}
.index .task-ideal .merit-list .item {
  max-width: 290px;
  width: 30%;
  padding-bottom: 40px;
  background-color: #ebf2fc;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item {
    width: 100%;
    max-width: auto;
    padding-bottom: 20px;
  }
}
.index .task-ideal .merit-list .item + .item {
  margin-left: 25px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item + .item {
    margin: 15px 0 0 0;
  }
}
.index .task-ideal .merit-list .item:nth-child(1) .image {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(1) .image {
    width: 122px;
    margin: 25px auto 0;
  }
}
.index .task-ideal .merit-list .item:nth-child(1) .title {
  margin-top: 36px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(1) .title {
    margin-top: 15px;
  }
}
.index .task-ideal .merit-list .item:nth-child(2) .image {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(2) .image {
    width: 139px;
    margin: 30px auto 0;
  }
}
.index .task-ideal .merit-list .item:nth-child(2) .title {
  margin-top: 27px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(2) .title {
    margin-top: 15px;
  }
}
.index .task-ideal .merit-list .item:nth-child(3) .image {
  margin-top: 48px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(3) .image {
    width: 134px;
    margin: 30px auto 0;
    position: relative;
    left: -8px;
  }
}
.index .task-ideal .merit-list .item:nth-child(3) .title {
  margin-top: 36px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item:nth-child(3) .title {
    margin-top: 15px;
  }
}
.index .task-ideal .merit-list .item .image {
  width: 100%;
  height: auto;
}
.index .task-ideal .merit-list .item .title {
  font-size: 2rem;
  line-height: 2.8rem;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item .title {
    font-size: 1.45rem;
  }
}
.index .task-ideal .merit-list .item .desc {
  font-size: 1.6rem;
  line-height: 2.8rem;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .merit-list .item .desc {
    font-size: 1.3rem;
    line-height: 2.4rem;
    margin-top: 2px;
  }
}
.index .task-ideal .button-wrap {
  margin: 70px auto 120px;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .button-wrap {
    margin: 30px auto 50px;
  }
}
.index .case {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 80px 20px;
}
@media screen and (max-width: 768px) {
  .index .case {
    padding: 30px 15px;
  }
}
.index .case h2 {
  text-align: center;
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1em;
  letter-spacing: -0.01em;
  margin-bottom: 55px;
}
@media screen and (max-width: 768px) {
  .index .case h2 {
    font-size: 1.9rem;
    line-height: 2.9rem;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.index .case-content {
  max-width: 950px;
  margin: 0 auto;
}
.index .case-study {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .index .case-study {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.index .case-item {
  width: 31.0526315789%;
  background-color: #fff;
  padding-bottom: 25px;
  -webkit-box-shadow: 0 0 26px rgba(49, 60, 71, 0.12);
          box-shadow: 0 0 26px rgba(49, 60, 71, 0.12);
}
@media screen and (max-width: 768px) {
  .index .case-item {
    width: 100%;
    -webkit-box-shadow: 0 0 13px rgba(49, 60, 71, 0.12);
            box-shadow: 0 0 13px rgba(49, 60, 71, 0.12);
  }
  .index .case-item:not(:last-child) {
    margin-bottom: 25px;
  }
}
.index .case-item figure img {
  width: 100%;
}
.index .case-item-text {
  padding: 20px 20px 4px;
}
.index .case-item-text h3 {
  text-align: center;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.6666666667em;
  letter-spacing: 0em;
  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;
  min-height: 10em;
}
@media screen and (max-width: 768px) {
  .index .case-item-text h3 {
    text-align: left;
    font-size: 1.6rem;
    line-height: 1.4375em;
    letter-spacing: 0em;
    min-height: auto;
  }
}
.index .case-item-logo {
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .index .case-item-logo {
    margin: 30px auto;
  }
}
.index .case-item-logo img {
  max-height: 80px;
}
.index .case-item-data {
  padding: 7px 5px;
  background-color: #eff0f0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 17px;
}
@media screen and (max-width: 768px) {
  .index .case-item-data {
    padding: 5px 10x;
    font-size: 1.1rem;
    line-height: 1.9090909091em;
    letter-spacing: 0em;
  }
}
.index .case-item-data dd + dt {
  margin-left: 10px;
}
.index .case-item-link {
  text-align: center;
}
.index .case-item-link a {
  color: #3c7be3;
  display: inline-block;
  padding: 0 5px;
  border-bottom: 2px solid #3c7be3;
}
@media screen and (max-width: 768px) {
  .index .case-item-link a {
    padding: 8px 5px 8px;
  }
}
@media (hover: hover) {
  .index .case-item-link a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .index .case-item-link a:hover {
    opacity: 0.7;
  }
}
.index .case-item-link a span {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 2.1333333333em;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 768px) {
  .index .case-item-link a span {
    font-size: 1.2rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.index .case-item-link a span::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8.7px;
  border-color: transparent transparent transparent #3c7be3;
  margin-left: 10px;
}
.index .case .button-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .index .case .button-wrap {
    margin-top: 30px;
  }
}

.index .document {
  position: relative;
  padding: 80px 0;
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #3C7BE3;
}
@media screen and (max-width: 768px) {
  .index .document {
    padding: 30px 15px;
  }
}
.index .document .heading {
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .index .document .heading {
    font-size: 1.9rem;
    line-height: 2.9rem;
  }
}
.index .document .document-content {
  display: flex;
  justify-content: center;
  gap: 74px;
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .index .document .document-content {
    flex-direction: column;
    gap: 10px;
    margin-top: 20px;
  }
}
.index .document .document-img {
  width: 248px;
}
@media screen and (max-width: 768px) {
  .index .document .document-img {
    width: 180px;
    margin-left: auto;
    margin-right: auto;
  }
}
.index .document .document-desc{
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .index .document .document-desc{
    margin-top: 10px;
  }
}
.index .document .document-text {
  font-size: 2.4rem;
  font-weight: bold;
  color: #fff;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .index .document .document-text {
    font-size: 1.6rem;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }
}
.index .document .document-btn {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .index .document .document-btn {
    margin-top: 20px;
  }
}
.index .document .document-btn a {
  width: 360px;
  background-color: #b40200;
  font-size: 1.6rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .index .document .document-btn a {
    width: 220px;
    font-size: 1.3rem;
  }
}
.index .document .document-btn a::after {
  content: none;
}

.index .price {
  padding: 80px 0;
  margin: 0 calc(50% - 50vw);
  overflow: hidden;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .index .price {
    padding: 30px 0;
  }
}
.index .price h2 {
  text-align: center;
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1em;
  letter-spacing: -0.01em;
  margin-bottom: 35px;
}
@media screen and (max-width: 768px) {
  .index .price h2 {
    font-size: 1.9rem;
    line-height: 2.9rem;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.index .price-text {
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
  margin-bottom: 55px;
}
@media screen and (max-width: 768px) {
  .index .price-text {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.index .nest {
  position: relative;
  background: #F3F2F2;
  margin: 0 calc(50% - 50vw);
  padding: 0px calc(50vw - 50%) 60px;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.index .nest .nest-bnr-image {
  max-width: 60%;
}
@media screen and (max-width: 768px) {
  .index .nest .nest-bnr-image {
    max-width: 90%;
  }
}
.index .nest a:hover{
  opacity: 0.6;
  transition: all 0.3s;
}

.index .contact {
  background: url(../../img/index/contact_bg.png) center top/cover no-repeat;
  margin: 0 calc(50% - 50vw);
  padding: 60px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .index .contact {
    background: url(../../img/index/contact_bg_sp.png) center top/cover no-repeat;
    padding: 40px 30px;
  }
}
.index .contact-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1060px) {
  .index .contact-list {
    -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;
  }
}
@media screen and (max-width: 768px) {
  .index .contact-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.index .contact-list li {
  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;
  text-align: center;
  width: 29.0434782609%;
  background-color: #fff;
  padding: 37px 0 49px;
}
@media screen and (max-width: 1060px) {
  .index .contact-list li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .index .contact-list li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.index .contact-list li + li {
  margin-left: 2.7826086957%;
}
@media screen and (max-width: 1060px) {
  .index .contact-list li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
.index .contact-list li:nth-child(1) figure {
  width: 41px;
}
@media screen and (max-width: 768px) {
  .index .contact-list li:nth-child(1) figure {
    width: 31.5px;
  }
}
.index .contact-list li:nth-child(2) figure {
  width: 47px;
}
@media screen and (max-width: 768px) {
  .index .contact-list li:nth-child(2) figure {
    width: 40.5px;
  }
}
.index .contact-list li:nth-child(3) figure {
  width: 54px;
}
@media screen and (max-width: 768px) {
  .index .contact-list li:nth-child(3) figure {
    width: 45.5px;
  }
}
.index .contact-list li figure {
  min-height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 14px;
}
@media screen and (max-width: 768px) {
  .index .contact-list li figure {
    min-height: 45px;
    margin-bottom: 15px;
  }
}
.index .contact-list li p {
  text-align: center;
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0.025em;
  font-weight: 400;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .index .contact-list li p {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.index .contact-button {
  margin-top: auto;
}
@media screen and (max-width: 768px) {
  .index .contact-button {
    height: auto;
  }
}
.index .contact-button a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #3c7be3;
  color: #fff;
  width: 276px;
  min-height: 50px;
  font-size: 14px;
  font-weight: 500;
  padding: 18px 30px;
  border-radius: 25px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .index .contact-button a {
    width: 190px;
    min-height: 31px;
    padding: 8px 15px 8px;
    border-radius: 31px;
  }
}
.index .contact-button a::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: 1px;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .index .contact-button a::after {
    right: 10px;
    border-width: 4px 0 4px 5px;
  }
}
@media (hover: hover) {
  .index .contact-button a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .index .contact-button a:hover {
    opacity: 0.7;
  }
}
.index .contact-button a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1em;
  letter-spacing: 0em;
  display: inline-block;
  padding-bottom: 1px;
}
@media screen and (max-width: 768px) {
  .index .contact-button a span {
    font-size: 1.1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}

.page-features {
  padding-bottom: 0;
}
.page-features .hero {
  background: #4b4346;
}
@media screen and (max-width: 768px) {
  .page-features .hero {
    background: url(../../img/features/hero_bg_sp.png) center top/cover no-repeat;
  }
}
.page-features .hero .section-inner {
  position: relative;
}
.page-features .hero .section-inner::before {
  content: "";
  width: 33.1304347826%;
  height: 256px;
  position: absolute;
  right: -25px;
  top: 0;
  bottom: 0;
  margin: auto;
  background: #4b4346 url(../../img/features/feature_kv.svg) center right/contain no-repeat;
}
@media screen and (max-width: 768px) {
  .page-features .hero .section-inner::before {
    display: none;
  }
}
.page-features .hero-body {
  position: relative;
  padding-right: 33.1304347826%;
}
@media screen and (max-width: 768px) {
  .page-features .hero-body {
    padding-right: 0;
  }
}
.page-features .hero-body p {
  letter-spacing: 0.01em;
}
.page-features .hero-body .hero-button a {
  width: 250px;
}
@media screen and (max-width: 768px) {
  .page-features .hero-body .hero-button a {
    width: 180px;
  }
}
.page-features .hero-body .hero-button a::after {
  border-width: 4px 0 4px 5px;
}
.page-features .content-nav {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .page-features .content-nav {
    padding: 20px 15px 0;
  }
}
.page-features .content-nav--bottom {
  padding-bottom: 20px;
  position: relative;
}
.page-features .content-nav--bottom::after {
  content: "";
  background: #fff;
  width: 100vw;
  height: 20px;
  position: absolute;
  left: 0;
  bottom: 0;
  margin: 0 calc(50% - 50vw);
}
@media screen and (max-width: 768px) {
  .page-features .content-nav--bottom {
    padding-bottom: 10px;
  }
  .page-features .content-nav--bottom::after {
    height: 10px;
  }
}
.page-features .content-nav ul {
  height: 136px;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 768px) {
  .page-features .content-nav ul {
    height: 85px;
  }
}
.page-features .content-nav li {
  width: 32.7826086957%;
}
@media screen and (max-width: 768px) {
  .page-features .content-nav li {
    width: 32.0689655172%;
  }
}
.page-features .content-nav li a {
  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: 23px 10px;
  background-color: #aaaaaa;
}
@media screen and (max-width: 768px) {
  .page-features .content-nav li a {
    text-align: center;
    padding: 15px 0;
    min-height: 60px;
  }
}
@media (hover: hover) {
  .page-features .content-nav li a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-features .content-nav li a:hover {
    opacity: 0.7;
  }
}
.page-features .content-nav li a.is-active {
  background-color: #fff;
  border-top: 6px solid #3c7be3;
  padding: 27px 10px 23px;
}
@media screen and (max-width: 768px) {
  .page-features .content-nav li a.is-active {
    border-width: 3px;
    padding: 16px 0;
    min-height: 65px;
  }
}
.page-features .content-nav li a.is-active span {
  color: #3c7be3;
}
.page-features .content-nav li a span {
  color: #fff;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.6666666667em;
  letter-spacing: -0.01em;
}
@media screen and (max-width: 768px) {
  .page-features .content-nav li a span {
    font-size: 1.1rem;
    line-height: 1.4090909091em;
    letter-spacing: -0.02em;
  }
}
.page-features .features-block {
  display: none;
}
.page-features .features-block .section-inner {
  max-width: 950px;
  margin: auto;
}
.page-features .features-block .section-inner.mod-width {
  max-width: 1010px;
}
.page-features .features-block.is-show {
  display: block;
}
.page-features .features-about {
  text-align: center;
  padding-top: 75px;
  margin-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .page-features .features-about {
    padding-top: 36px;
    margin-bottom: 60px;
  }
}
.page-features .features-about-title {
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .features-about-title {
    margin-bottom: 16px;
  }
}
.page-features .features-about-title span {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1.7222222222em;
  letter-spacing: -0.01em;
  padding: 0 10px;
  display: inline-block;
  border-bottom: 3px solid #000;
}
@media screen and (max-width: 768px) {
  .page-features .features-about-title span {
    font-size: 2.2rem;
    line-height: 2.0454545455em;
    letter-spacing: 0em;
    border-width: 2px;
    padding: 0;
  }
}
.page-features .features-about-lead {
  font-weight: 700;
  font-size: 2.2rem;
  line-height: 1.8181818182em;
  letter-spacing: 0em;
  margin-bottom: 35px;
}
@media screen and (max-width: 768px) {
  .page-features .features-about-lead {
    text-align: left;
    font-size: 1.5rem;
    line-height: 1.6em;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.page-features .features-about-lead b {
  font-weight: 700;
  color: #c40161;
}
.page-features .features-about-text {
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .page-features .features-about-text {
    text-align: left;
    font-size: 1.4rem;
    line-height: 1.5714285714em;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.page-features .features-about-text b {
  font-weight: 400;
  color: #c40161;
}
.page-features .features-about-illust {
  max-width: 1010px;
  margin: auto;
}
.page-features .features-figure {
  background-color: #ebf2fc;
  margin: 0 calc(50% - 50vw);
  padding: 60px calc(50vw - 50%) 90px;
}
@media screen and (max-width: 768px) {
  .page-features .features-figure {
    padding: 25px calc(50vw - 50%) 50px;
  }
}
.page-features .features-figure-title {
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .page-features .features-figure-title {
    margin-bottom: 25px;
  }
}
.page-features .features-figure-title span {
  font-weight: 700;
  font-size: 2.2rem;
  line-height: 1.8181818182em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .features-figure-title span {
    font-size: 1.8rem;
    line-height: 1.5555555556em;
    letter-spacing: 0em;
  }
}
.page-features .features-figure-illust {
  max-width: 975px;
  margin: auto;
}
.page-features .features-movie {
  text-align: center;
  padding: 90px 0 80px;
}
@media screen and (max-width: 768px) {
  .page-features .features-movie {
    padding: 20px 0 60px;
  }
}
.page-features .features-movie-title span {
  font-size: 2.4rem;
  font-weight: 700;
  color: #3c7be3;
  border-bottom: 2px solid #3c7be3;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .page-features .features-movie-title span {
    font-size: 1.95rem;
    line-height: 3.3rem;
    border-width: 1px;
  }
}
.page-features .features-movie-lead {
  font-size: 2.4rem;
  font-weight: 700;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .page-features .features-movie-lead {
    font-size: 1.95rem;
    line-height: 2.9rem;
    margin-top: 8px;
  }
}
.page-features .features-movie .button-wrap {
  margin-top: 45px;
}
@media screen and (max-width: 768px) {
  .page-features .features-movie .button-wrap {
    margin-top: 25px;
  }
}
.page-features .section-nav {
  background-color: #4b4346;
  margin: 0 calc(50% - 50vw);
  padding: 30px calc(50vw - 50%) 15px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav {
    padding: 13px 15px 13px;
  }
}
.page-features .section-nav.l-features ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features ul {
    -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;
  }
}
.page-features .section-nav.l-features li {
  position: relative;
  width: 20%;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li {
    width: 100%;
  }
}
.page-features .section-nav.l-features li:not(:last-child)::after {
  content: "";
  width: 1px;
  height: 90%;
  background-color: rgba(247, 247, 247, 0.2);
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li:not(:last-child)::after {
    width: 100%;
    height: 1px;
    top: inherit;
  }
}
.page-features .section-nav.l-features li a {
  display: block;
  text-align: center;
  padding-bottom: 18px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 11px 0;
  }
}
@media (hover: hover) {
  .page-features .section-nav.l-features li a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-features .section-nav.l-features li a:hover {
    opacity: 0.7;
  }
}
.page-features .section-nav.l-features li a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 5.5px 0 5.5px;
  border-color: #fff transparent transparent transparent;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li a::after {
    border-width: 5px 4.5px 0 4.5px;
    left: inherit;
    top: 0;
  }
}
.page-features .section-nav.l-features li .section-nav-number {
  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;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 73px;
  height: 70px;
  margin: 0 auto 5px;
  background: url(../../img/common/balloon_number_wt.svg) center/contain no-repeat;
  color: #4b4346;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-number {
    width: 60px;
    height: 58px;
    margin: 0;
  }
}
.page-features .section-nav.l-features li .section-nav-number span {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1em;
  letter-spacing: 0em;
  margin-bottom: 3px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-number span {
    font-size: 1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-features .section-nav.l-features li .section-nav-number i {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.9rem;
  line-height: 1em;
  letter-spacing: 0em;
}
.page-features .section-nav.l-features li .section-nav-number i else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-number i {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-features .section-nav.l-features li .section-nav-text {
  color: #fff;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.3333333333em;
  letter-spacing: 0em;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-text {
    font-size: 1.6rem;
    line-height: 1.375em;
    letter-spacing: 0em;
    padding-left: 12px;
    text-align: left;
    margin-top: 0;
  }
}
.page-features .section-nav.l-features li .section-nav-text.mod-margin {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-text.mod-margin {
    margin-top: 0;
  }
}
.page-features .section-nav.l-features li .section-nav-text span {
  font-size: 1rem;
  border: 1px solid #fff;
  border-radius: 3px;
  padding: 0px 7px 1px;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features li .section-nav-text span {
    display: inline-block;
    margin-top: 5px;
    font-size: 1.1rem;
    padding: 0 7px;
  }
}
.page-features .section-nav.l-features.l-features02 li {
  position: relative;
  width: 25%;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features.l-features02 li {
    width: 100%;
  }
}
.page-features .section-nav.l-features.l-features03 li {
  position: relative;
  width: 16.66%;
}
@media screen and (max-width: 768px) {
  .page-features .section-nav.l-features.l-features03 li {
    width: 100%;
  }
}
.page-features .features-content {
  padding-top: 90px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content {
    padding-top: 40px;
    padding-bottom: 60px;
  }
}
.page-features .features-content.mod-padding {
  padding-bottom: 50px;
}
.page-features .features-content.l-bg-gray {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 90px calc(50vw - 50%) 120px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content.l-bg-gray {
    padding: 36px 15px 60px;
  }
}
.page-features .features-content .l-nomargin {
  margin-bottom: 0;
}
.page-features .features-content .l-nomargin + .features-content-text {
  margin-top: 35px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content .l-nomargin + .features-content-text {
    margin-top: 25px;
  }
}
.page-features .features-content-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: -12px;
  margin-bottom: 16px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-title {
    margin-left: -4px;
  }
}
.page-features .features-content-title h3 {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-weight: 700;
  font-size: 3.2rem;
  line-height: 1.125em;
  letter-spacing: 0em;
  padding-left: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-title h3 {
    font-size: 2.2rem;
    line-height: 1.2954545455em;
    letter-spacing: 0em;
    padding-left: 15px;
  }
}
@media screen and (max-width: 768px) {
  .page-features .features-content-title h3.mod-margin {
    margin-top: 10px;
  }
}
.page-features .features-content-title h3 small {
  font-weight: 700;
  font-size: 1.9rem;
  line-height: 1.8947368421em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-title h3 small {
    display: block;
    font-size: 1.3rem;
    line-height: 1.3846153846em;
    letter-spacing: 0em;
  }
  .page-features .features-content-title h3 small + i {
    margin-left: 4px;
  }
}
.page-features .features-content-title h3 i {
  display: inline-block;
  vertical-align: middle;
  color: #3c7be3;
  font-size: 1.4rem;
  line-height: 2.0714285714em;
  letter-spacing: 0em;
  border: 1px solid #3c7be3;
  border-radius: 3px;
  padding: 0 10px;
  margin-left: 15px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-title h3 i {
    vertical-align: auto;
    font-size: 1.1rem;
    line-height: 1.8181818182em;
    letter-spacing: 0em;
    padding: 0 6px;
    margin-left: 0;
  }
}
.page-features .features-content-number {
  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;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 83px;
  height: 81px;
  background: url(../../img/common/balloon_number.png) center/contain no-repeat;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-number {
    width: 70px;
    height: 69px;
  }
}
.page-features .features-content-number span {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1em;
  letter-spacing: 0em;
  margin-bottom: 4px;
}
.page-features .features-content-number i {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2.2rem;
  line-height: 1em;
  letter-spacing: 0em;
}
.page-features .features-content-number i else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-number i {
    font-size: 2.2rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-text {
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-text {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.page-features .features-content-text b {
  color: #c40161;
  font-weight: 400;
}
.page-features .features-content-bttext {
  text-align: center;
  margin: 56px 0 38px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-bttext {
    margin: 42px 0 22px;
  }
}
.page-features .features-content-bttext span {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #f9e5ef));
  background: linear-gradient(transparent 60%, #f9e5ef 60%);
  font-weight: 700;
  font-size: 2.5rem;
  line-height: 2em;
  letter-spacing: 0.01em;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-bttext span {
    font-size: 1.5rem;
    line-height: 1.8666666667em;
    letter-spacing: 0.01em;
  }
}
.page-features .features-content-bttext + .button-wrap.button-border.l-single a {
  width: 460px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-bttext + .button-wrap.button-border.l-single a {
    width: 280px;
  }
}
.page-features .features-content-func {
  background-color: #ebf2fc;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 25px 15px 25px 0;
  margin-top: 20px;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-func {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 28px 15px 25px;
    margin-top: 15px;
    margin-bottom: 35px;
  }
}
.page-features .features-content-func p {
  width: 214px;
  text-align: center;
  color: #3c7be3;
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0em;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-func p {
    width: 100%;
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 23px;
  }
}
.page-features .features-content-func li {
  position: relative;
  padding-left: 1em;
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-func li {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-func li::before {
  content: "";
  width: 7px;
  height: 7px;
  background-color: #3c7be3;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 12px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-func li::before {
    width: 5px;
    height: 5px;
    top: 9px;
  }
}
.page-features .features-content-image {
  margin-bottom: 70px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-image {
    margin-bottom: 50px;
  }
}
.page-features .features-content-image + .features-content-image {
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-image + .features-content-image {
    margin-top: 42px;
  }
}
.page-features .features-content-image.mod-margin {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-image.mod-margin {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 768px) {
  .page-features .features-content-video {
    background: url(../../img/features/movie_thumb.png) center/cover no-repeat;
  }
}
.page-features .features-content-video video {
  width: 100%;
  height: 100%;
}
.page-features .features-content-label {
  margin-bottom: 22px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-label {
    margin-bottom: 15px;
  }
}
.page-features .features-content-label span {
  font-weight: 700;
  display: inline-block;
  background-color: #4b4346;
  color: #fff;
  font-size: 2.1rem;
  line-height: 1.619047619em;
  letter-spacing: 0em;
  padding: 0 10px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-label span {
    padding: 7px 10px;
    font-size: 1.6rem;
    line-height: 1.25em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-label span ~ span {
  padding-left: 0;
  margin-left: -10px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-label span ~ span {
    padding-left: 10px;
    margin-left: 0;
    margin-top: 7px;
  }
}
.page-features .features-content-label span small {
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-label span small {
    display: block;
    font-size: 1.3rem;
    line-height: 1.5384615385em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-option {
  border: 2px solid #3c7be3;
  padding: 46px 62px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-option {
    padding: 26px 20px;
    border-width: 1px;
  }
}
.page-features .features-content-option:not(:first-of-type) {
  margin-top: 20px;
}
.page-features .features-content-arrow {
  width: 47px;
  margin: 15px auto;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-arrow {
    width: 23px;
    margin: 10px auto;
  }
}
.page-features .features-content-heading {
  font-size: 2.2rem;
  font-weight: 700;
  color: #3c7be3;
  margin-bottom: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-heading {
    display: block;
    font-size: 1.8rem;
    line-height: 2.4rem;
    margin-bottom: 15px;
  }
}
.page-features .features-content-heading span {
  font-size: 1.4rem;
  border: 1px solid #3c7be3;
  border-radius: 3px;
  padding: 6px 8px;
  margin-left: 15px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-heading span {
    margin: 10px 0 0 0;
    font-size: 1.1rem;
    padding: 1px 6px;
  }
}
.page-features .features-content-note {
  font-size: 1.4rem;
  line-height: 1.7857142857em;
  letter-spacing: 0em;
  margin-top: 8px;
  margin-bottom: 33px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-note {
    margin-top: 6px;
    font-size: 1rem;
    line-height: 1.6em;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.page-features .features-content-note li {
  text-indent: -1em;
  margin-left: 1em;
}
.page-features .features-content-operation {
  max-width: 600px;
  margin: auto;
}
.page-features .features-content-operation a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 21px 60px 21px 23px;
  border: 1px solid #b6b6b6;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-operation a {
    padding: 10px 20px 10px 10px;
  }
}
@media (hover: hover) {
  .page-features .features-content-operation a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-features .features-content-operation a:hover {
    opacity: 0.7;
  }
}
.page-features .features-content-operation a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5.5px 0 5.5px 6px;
  border-color: transparent transparent transparent #c40161;
  position: absolute;
  right: 45px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-operation a::after {
    right: 10px;
    border-width: 4.25px 0 4.25px 6px;
  }
}
@media screen and (max-width: 768px) {
  .page-features .features-content-operation a figure {
    width: 38.4615384615%;
  }
}
.page-features .features-content-operation a p {
  padding-left: 30px;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.6666666667em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-operation a p {
    font-size: 1.2rem;
    line-height: 1.3333333333em;
    letter-spacing: 0em;
    padding-left: 10px;
  }
  .page-features .features-content-operation a p small {
    font-size: 1rem;
    line-height: 1.6em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-operation a p span {
  display: block;
  color: #c40161;
  font-weight: 400;
  padding-top: 7px;
  font-size: 1.4rem;
  line-height: 1.7857142857em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-operation a p span {
    padding-top: 4px;
    font-size: 1.1rem;
    line-height: 1.4545454545em;
    letter-spacing: 0em;
  }
}
.page-features .features-content-support {
  background-color: #ebf2fc;
  padding: 60px 60px 55px;
  margin: 20px auto 85px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support {
    padding: 20px 10px;
    margin: 20px auto 45px;
  }
}
.page-features .features-content-support .title {
  font-size: 2.1rem;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .title {
    font-size: 1.4rem;
    line-height: 2rem;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
  }
}
.page-features .features-content-support .logo-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 606px;
  margin: 42px auto;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .logo-list {
    width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 5px auto 0;
  }
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .logo-list .item {
    width: 40%;
    text-align: center;
  }
  .page-features .features-content-support .logo-list .item:nth-child(n+2) {
    margin-top: 18px;
  }
  .page-features .features-content-support .logo-list .item.kintone {
    margin-top: 10px;
  }
  .page-features .features-content-support .logo-list .item.kintone img {
    width: 99px;
  }
  .page-features .features-content-support .logo-list .item.sansan img {
    width: 76px;
  }
  .page-features .features-content-support .logo-list .item.amazon img {
    width: 80px;
  }
  .page-features .features-content-support .logo-list .item.google img {
    width: 66px;
  }
}
.page-features .features-content-support .buttons {
  background-color: #fff;
  padding: 45px 0;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .buttons {
    margin-top: 20px;
    padding: 18px 0 10px;
  }
}
.page-features .features-content-support .buttons .button-wrap {
  margin-top: 45px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .buttons .button-wrap {
    margin-top: 15px;
  }
}
.page-features .features-content-support .buttons .button-wrap a {
  width: 294px;
  padding: 12px 30px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .buttons .button-wrap a {
    width: 180px;
    padding: 4px 0;
    margin-bottom: 10px;
  }
}
.page-features .features-content-support .buttons .button-wrap a span {
  font-size: 1.5rem;
  line-height: 2rem;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-support .buttons .button-wrap a span {
    font-size: 1.1rem;
    line-height: 1.6rem;
  }
}
.page-features .features-content-box {
  border-bottom: 1px solid #b1b0b0;
  padding-bottom: 80px;
  margin-bottom: 75px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-box {
    padding-bottom: 40px;
    margin-bottom: 40px;
  }
}
.page-features .features-content-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail {
    padding: 0;
    margin-bottom: 15px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-features .features-content-detail .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fff;
  max-width: 460px;
  width: calc(50% - 10px);
  padding: 43px 73px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .box {
    width: 100%;
    padding: 20px 25px;
    max-width: 100%;
  }
  .page-features .features-content-detail .box + .box {
    margin-top: 10px;
  }
}
.page-features .features-content-detail .box .icon {
  margin-right: 38px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .box .icon {
    width: 33px;
    margin-right: 30px;
  }
}
.page-features .features-content-detail .box .text {
  font-size: 1.6rem;
  line-height: 2.5rem;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .box .text {
    font-size: 1.3rem;
    line-height: 2rem;
  }
}
.page-features .features-content-detail .image-box {
  text-align: center;
  background-color: #f3f2f2;
  max-width: 460px;
  width: calc(50% - 10px);
  min-height: 400px;
  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;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .image-box {
    width: 100%;
    max-width: 100%;
    padding: 15px;
    min-height: auto;
  }
  .page-features .features-content-detail .image-box + .image-box {
    margin-top: 20px;
  }
  .page-features .features-content-detail .image-box.join img {
    width: 155px;
  }
}
.page-features .features-content-detail .image-box .caption {
  margin-top: 20px;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .image-box .caption {
    font-size: 1.3rem;
    margin-top: 15px;
  }
}
.page-features .features-content-detail .mbc-icon {
  margin: -18px 20px 0 0;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-detail .mbc-icon {
    width: 100px;
    margin: 0 auto;
  }
}
.page-features .features-content-detail picture {
  display: block;
  text-align: center;
}
.page-features .features-content-column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.page-features .demo {
  margin-bottom: 110px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-features .demo {
    margin-bottom: 80px;
  }
}
.page-features .demo-title {
  text-align: center;
  margin: 0 calc(50% - 50vw) 110px;
  padding: 50px calc(50vw - 50%) 45px;
  background-color: #4b4346;
}
@media screen and (max-width: 768px) {
  .page-features .demo-title {
    padding: 30px 15px 25px;
    margin-bottom: 38px;
  }
}
.page-features .demo-title h2 {
  color: #fff;
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1em;
  letter-spacing: -0.01em;
  margin-bottom: 14px;
}
@media screen and (max-width: 768px) {
  .page-features .demo-title h2 {
    font-size: 2.2rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-features .demo-title p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .demo-title p {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0em;
  }
}
.page-features .demo-content {
  max-width: 1070px;
  margin: 0 auto 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-bottom: 38px;
  }
}
.page-features .demo-content figure {
  text-align: center;
  width: 59.4736842105%;
  -webkit-transform: translateX(-36px);
          transform: translateX(-36px);
}
@media screen and (max-width: 768px) {
  .page-features .demo-content figure {
    width: 100%;
    -webkit-transform: translateX(0);
            transform: translateX(0);
    margin-bottom: 38px;
  }
}
.page-features .demo-content ul {
  width: 435px;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content ul {
    width: 100%;
  }
}
.page-features .demo-content li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 30px 0 30px 10px;
  border-bottom: 1px solid #cccccc;
}
.page-features .demo-content li:last-child {
  padding: 40px 0 40px 10px;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li:last-child {
    padding: 10px 0 10px 10px;
  }
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li {
    padding: 10px 0 10px 10px;
  }
}
.page-features .demo-content li::before {
  content: "";
  min-width: 29px;
  height: 27px;
  background: url(../../img/features/checkbox@2x.png) center/contain no-repeat;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li::before {
    min-width: 20px;
    height: 18px;
  }
}
.page-features .demo-content li span {
  padding-left: 15px;
  font-weight: 500;
  font-size: 2.2rem;
  line-height: 1em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li span {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    padding-left: 6px;
    font-size: 1.6rem;
  }
}
.page-features .demo-content li .small {
  padding-left: 0;
  font-size: 1.6rem;
  display: inline-block;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li .small {
    font-size: 1.1rem;
    margin-top: 10px;
  }
}
.page-features .demo-content li .large {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  padding-left: 0;
  font-size: 8rem;
  color: #3c7be3;
  margin-top: -45px;
  display: inline-block;
}
.page-features .demo-content li .large else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-features .demo-content li .large {
    font-size: 5rem;
    margin-top: -25px;
  }
}
.page-features .demo .button-wrap {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .page-features .demo .button-wrap {
    margin-top: 35px;
  }
}
.page-features .demo .button-wrap a {
  width: 310px;
}
@media screen and (max-width: 768px) {
  .page-features .demo .button-wrap a {
    width: 220px;
  }
}
.page-features .ver63 {
  background: #f3f2f2;
  line-height: 1.8125em;
  padding: 40px 60px;
  margin-bottom: 60px;
  font-size: 1.6rem;
  letter-spacing: 0em;
}
.page-features .ver63-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.page-features .ver63-box dl {
  width: 48%;
}
.page-features .ver63-box dt {
  font-weight: bold;
  margin: 20px 0 5px;
}
.page-features .ver63-box dd p {
  font-size: 1.4rem;
  margin-top: 5px;
}
.page-features .ver63 .note li,
.page-features .features-content-image .note li {
  text-indent: -1em;
  padding-left: 1em;
  font-size: 1.2rem;
  margin-top: 1em;
}
.page-features .ver63 .ico-window {
  text-decoration: underline;
  color: #000;
  background: url(/common/img/ico_window_bl.png) right 4px/8px auto no-repeat;
  padding-right: 13px;
  display: inline-block;
  text-indent: 0;
  margin-right: 3px;
}
.page-features .ver63 .ico-window:hover {
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-box {
    padding-bottom: 40px;
    margin-bottom: 40px;
  }
  .page-features .ver63 {
    padding: 20px;
    margin-bottom: 30px;
    font-size: 1.3rem;
    line-height: 1.6923076923em;
  }
  .page-features .ver63-box dl {
    width: 100%;
  }
  .page-features .ver63-box dd p {
    font-size: 1.2rem;
  }
  .page-features .ver63 .note li {
    font-size: 1.1rem;
    line-height: 1.5;
    margin-top: 1.5em;
  }
  .page-features .ver63 .ico-window {
    background-position: right 2px;
  }
}
.page-features #feature01-section03 .button-wrap a,
.page-features #feature01-section04 .button-wrap:not(.button-modal) a {
  width: auto;
  padding: 27px 50px 27px 40px;
  margin-top: 50px;
}
.page-features #feature01-section04 .button-wrap.button-modal a {
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .page-features #feature01-section03 .button-wrap a,
  .page-features #feature01-section04 .button-wrap:not(.button-modal) a {
    margin-top: 30px;
    padding: 13px 30px 13px 25px;
  }
}
.page-features #featurea-nav {
  position: relative;
  top: -40px;
}
@media screen and (max-width: 768px) {
  .page-features #featurea-nav {
    top: 0;
  }
}

.page-price {
  padding-bottom: 0;
}
.page-price .hero {
  background: url(../../img/price/hero_bg_pc.png) center top/cover no-repeat;
}
@media screen and (max-width: 768px) {
  .page-price .hero {
    background: url(../../img/price/hero_bg_sp.png) center top/cover no-repeat;
  }
}
.page-price .content-nav {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 30px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .page-price .content-nav {
    padding: 20px 15px;
  }
}
.page-price .content-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-price .content-nav li {
  width: 48.6956521739%;
  background-color: #fff;
  border-left: 4px solid #3c7be3;
}
.page-price .content-nav li + li {
  margin-left: 10px;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li + li {
    margin-left: 0;
  }
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li {
    width: 100%;
    border-width: 3px;
  }
  .page-price .content-nav li:not(:last-child) {
    margin-bottom: 10px;
  }
}
.page-price .content-nav li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 11px 50px 11px 0;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li a {
    padding: 11px 50px 11px 0;
  }
}
@media (hover: hover) {
  .page-price .content-nav li a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-price .content-nav li a:hover {
    opacity: 0.7;
  }
}
.page-price .content-nav li a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 5.5px 0 5.5px;
  border-color: #3c7be3 transparent transparent transparent;
  position: absolute;
  right: 30px;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li a::after {
    right: 14px;
    border-width: 5.5px 5px 0 5px;
  }
}
.page-price .content-nav li a i {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 55px;
  height: 54px;
  margin-left: 26px;
  background: url(../../img/common/balloon_number.png) center/contain no-repeat;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #fff;
  font-size: 1.5rem;
  line-height: 1em;
  letter-spacing: 0em;
}
.page-price .content-nav li a i else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li a i {
    width: 35px;
    height: 34px;
    font-size: 1.15rem;
    line-height: 1.0434782609em;
    letter-spacing: 0em;
    margin-left: 11px;
  }
}
.page-price .content-nav li a span {
  padding-left: 20px;
  color: #3c7be3;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.5625em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .content-nav li a span {
    font-size: 1.3rem;
    line-height: 1.5384615385em;
    letter-spacing: 0em;
    padding-left: 11px;
  }
}
.page-price .price-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .page-price .price-title {
    margin-left: -4px;
  }
}
.page-price .price-title i {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 70px;
  height: 69px;
  background: url(../../img/common/balloon_number.png) center/contain no-repeat;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #fff;
  font-size: 1.9rem;
  line-height: 1em;
  letter-spacing: 0em;
  margin-right: 20px;
}
.page-price .price-title i else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .price-title i {
    font-size: 1.9rem;
    line-height: 1em;
    letter-spacing: 0em;
    width: 60px;
    height: 59px;
    margin-right: 13px;
  }
}
.page-price .price-title span {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .price-title span {
    font-size: 2.2rem;
    line-height: 1.2272727273em;
    letter-spacing: 0em;
  }
}
.page-price .price-text {
  font-size: 1.6rem;
  line-height: 1.8125em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .price-text {
    font-size: 1.3rem;
    line-height: 1.6923076923em;
    letter-spacing: 0em;
  }
}
.page-price .price-text.l-center {
  text-align: center;
}
.page-price .price-illust.l-column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-price .price-illust.l-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-price .price-illust.l-column figure {
  text-align: center;
  width: 47.7894736842%;
}
@media screen and (max-width: 768px) {
  .page-price .price-illust.l-column figure {
    width: 100%;
  }
  .page-price .price-illust.l-column figure:not(:last-child) {
    margin-bottom: 15px;
  }
}
.page-price .price-content {
  max-width: 950px;
  margin: auto;
}
.page-price .price01 {
  padding: 90px 0 120px;
}
@media screen and (max-width: 768px) {
  .page-price .price01 {
    padding: 40px 0 0;
  }
}
.page-price .price01 .price-title {
  margin-bottom: 13px;
}
@media screen and (max-width: 768px) {
  .page-price .price01 .price-title {
    margin-bottom: 15px;
  }
}
.page-price .price01 .price-text {
  margin-bottom: 35px;
}
@media screen and (max-width: 768px) {
  .page-price .price01 .price-text {
    margin-bottom: 25px;
  }
}
.page-price .price01 .price-illust {
  margin-bottom: 52px;
}
@media screen and (max-width: 768px) {
  .page-price .price01 .price-illust {
    margin-bottom: 35px;
  }
  .page-price .price01 .price-illust.l-graph {
    overflow: auto;
  }
  .page-price .price01 .price-illust.l-graph::-webkit-scrollbar {
    height: 10px;
  }
  .page-price .price01 .price-illust.l-graph::-webkit-scrollbar-track {
    border-radius: 10px;
    background: #f5f5f5;
  }
  .page-price .price01 .price-illust.l-graph::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background: #3c7be3;
  }
  .page-price .price01 .price-illust.l-graph figure {
    width: 747px;
    padding-bottom: 25px;
  }
}
.page-price .price01 .price-illust.l-column {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  .page-price .price01 .price-illust.l-column {
    margin-bottom: 40px;
  }
}
.page-price .price02 {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 105px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .page-price .price02 {
    padding: 40px 15px 60px;
  }
}
.page-price .price02 .price-title {
  margin-bottom: 42px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-title {
    margin-bottom: 20px;
  }
}
.page-price .price02 .price-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-price .price02 .price-list .price-item {
  position: relative;
  width: 23.8947368421%;
  padding: 30px 10px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item {
    width: 100%;
    padding: 25px 10px 30px;
  }
}
.page-price .price02 .price-list .price-item:nth-child(odd) {
  background-color: #eedae3;
}
.page-price .price02 .price-list .price-item:nth-child(even) {
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item:not(:last-child) {
    margin-bottom: 10px;
  }
}
.page-price .price02 .price-list .price-item:not(:last-child)::after {
  content: "";
  width: 28px;
  height: 28px;
  background: url(../../img/price/price02_arrow.svg) center/contain no-repeat;
  position: absolute;
  right: -21px;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item:not(:last-child)::after {
    width: 24px;
    height: 24px;
    left: 0;
    right: 0;
    top: inherit;
    bottom: -17px;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}
.page-price .price02 .price-list .price-item-number {
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-number {
    margin-bottom: 15px;
  }
}
.page-price .price02 .price-list .price-item-number span {
  color: #3c7be3;
  display: inline-block;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.9rem;
  line-height: 1em;
  letter-spacing: 0.02em;
  padding-bottom: 12px;
  border-bottom: 1px solid #3c7be3;
}
.page-price .price02 .price-list .price-item-number span else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-number span {
    font-size: 1.4rem;
    line-height: 1em;
    letter-spacing: -0.02em;
    padding-bottom: 7px;
  }
}
.page-price .price02 .price-list .price-item h3 {
  text-align: center;
  color: #3c7be3;
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.3em;
  letter-spacing: -0.01em;
  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: 3em;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item h3 {
    font-size: 1.4rem;
    line-height: 1.5714285714em;
    letter-spacing: 0em;
    min-height: auto;
    margin-bottom: 12px;
  }
}
.page-price .price02 .price-list .price-item-text {
  text-align: center;
  font-size: 1.4rem;
  line-height: 1.6428571429em;
  letter-spacing: -0.02em;
  min-height: 5em;
  margin-bottom: 17px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-text {
    font-size: 1.1rem;
    line-height: 1.6363636364em;
    letter-spacing: -0.02em;
    margin-bottom: 0;
    min-height: auto;
  }
}
.page-price .price02 .price-list .price-item-link {
  text-align: center;
  margin-top: auto;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-link {
    margin-top: 14px;
  }
}
.page-price .price02 .price-list .price-item-link a {
  position: relative;
  color: #3c7be3;
  display: inline-block;
  padding: 0 20px 5px 5px;
  border-bottom: 2px solid #3c7be3;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-link a {
    border-width: 2px;
    padding-right: 14px;
  }
}
@media (hover: hover) {
  .page-price .price02 .price-list .price-item-link a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-price .price02 .price-list .price-item-link a:hover {
    opacity: 0.7;
  }
}
.page-price .price02 .price-list .price-item-link a::after {
  content: "";
  position: absolute;
  right: 5px;
  bottom: 7px;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8.7px;
  border-color: transparent transparent transparent #3c7be3;
  margin-left: 10px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-link a::after {
    border-width: 4px 0 4px 6px;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
}
.page-price .price02 .price-list .price-item-link a span {
  text-align: center;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.3333333333em;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .price-list .price-item-link a span {
    font-size: 1.2rem;
    line-height: 1.5em;
    letter-spacing: 0em;
  }
}
.page-price .price02 .button-wrap {
  margin-top: 52px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .button-wrap {
    margin-top: 27px;
  }
}
.page-price .price02 .button-wrap a {
  width: 360px;
}
@media screen and (max-width: 768px) {
  .page-price .price02 .button-wrap a {
    width: 240px;
  }
}
.page-price .price-graph {
  background-color: #e0e6f0;
  padding: 57px 60px 50px;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph {
    padding: 30px 15px;
  }
}
.page-price .price-graph + .price-graph {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph + .price-graph {
    margin-bottom: 25px;
  }
}
.page-price .price-graph .cloud-table-wrap {
  overflow: auto;
}
.page-price .price-graph .cloud-table-wrap::-webkit-scrollbar {
  height: 10px;
}
.page-price .price-graph .cloud-table-wrap::-webkit-scrollbar-track {
  border-radius: 10px;
  background: #f5f5f5;
}
.page-price .price-graph .cloud-table-wrap::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: #3c7be3;
}
.page-price .price-graph .price-graph-title {
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
  color: #3c7be3;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .price-graph-title {
    font-size: 1.8rem;
  }
}
.page-price .price-graph .price-graph-desc {
  font-size: 1.6rem;
  text-align: center;
  margin-top: 35px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .price-graph-desc {
    text-align: left;
    font-size: 1.3rem;
    margin-top: 15px;
    line-height: 2.3rem;
  }
}
.page-price .price-graph .price-graph-note {
  font-size: 1.2rem;
  line-height: 2rem;
  text-align: center;
  margin-top: 10px;
  padding-left: 1em;
  text-indent: -1em;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .price-graph-note {
    text-align: left;
    font-size: 1rem;
    line-height: 1.6rem;
    margin-top: 5px;
  }
}
.page-price .price-graph .price-graph-note.l-right {
  text-align: right;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .price-graph-note.l-right {
    margin-top: 10px;
  }
}
.page-price .price-graph .price-graph-note.l-left {
  text-align: left;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .price-graph-note.l-left {
    margin-top: 10px;
  }
}
.page-price .price-graph .price-graph-note.l-left + .price-graph-note {
  margin-top: 0;
}
.page-price .price-graph .premise-table-wrap {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .page-price .price-graph .premise-table-wrap {
    margin-top: 15px;
    overflow: auto;
  }
}
.page-price .price-graph .premise-table-wrap::-webkit-scrollbar {
  height: 10px;
}
.page-price .price-graph .premise-table-wrap::-webkit-scrollbar-track {
  border-radius: 10px;
  background: #f5f5f5;
}
.page-price .price-graph .premise-table-wrap::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: #3c7be3;
}
.page-price .premise-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  background-color: #f5f5f5;
}
.page-price .premise-table-wrap th {
  background-color: #3c7be3;
  color: #fff;
  padding: 15px 10px;
  line-height: 1.2;
  font-weight: bold;
  text-align: center;
  font-size: 1.8rem;
}
.page-price .premise-table-wrap th + th {
  border-left: 2px solid #fff;
}
.page-price .premise-table-wrap th span {
  font-size: 1.2rem;
}
.page-price .premise-table-wrap td {
  padding: 15px 10px;
  line-height: 1.5;
  text-align: center;
  vertical-align: middle;
  font-size: 1.4rem;
}
.page-price .premise-table-wrap .pro {
  text-align: center;
  background: #dcdcdc;
}
.page-price .premise-table-wrap tr:last-child td:first-child,
.page-price .premise-table-wrap tr:last-child td {
  border-top: 2px solid #fff;
  border-bottom: none;
}
.page-price .premise-table-wrap .pro em {
  font-weight: bold;
  font-size: 1.8rem;
}
.page-price .premise-table-wrap .price {
  font-weight: 700;
  font-size: 1.2rem;
  border-bottom: 2px solid #ccc;
}
.page-price .premise-table-wrap .price + .price {
  border-left: 2px solid #ccc;
}
.page-price .premise-table-wrap .price span {
  display: block;
}
.page-price .premise-table-wrap .price i {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 2.8rem;
  color: #3c7be3;
  margin: 2px 5px 0;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table-wrap table {
    min-width: 600px;
  }
  .page-price .premise-table-wrap th {
    font-size: 1.4rem;
    line-height: 1.5;
  }
  .page-price .premise-table-wrap th span {
    font-size: 1.1rem;
  }
  .page-price .premise-table-wrap td {
    font-size: 1.2rem;
    line-height: 1.6;
  }
  .page-price .premise-table-wrap .pro em {
    font-size: 1.5rem;
  }
  .page-price .premise-table-wrap .price {
    font-size: 1rem;
  }
  .page-price .premise-table-wrap .price i {
    font-size: 1.8rem;
  }
}
.page-price .premise-table {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table {
    width: 100%;
  }
}
.page-price .premise-table .head {
  text-align: center;
  background-color: #3c7be3;
  color: #fff;
  font-size: 2.2rem;
  line-height: 2.8rem;
  font-weight: 700;
  padding: 15px 0 20px;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table .head {
    font-size: 1.6rem;
    line-height: 2rem;
    padding: 8px 0 10px;
  }
}
.page-price .premise-table .head span {
  font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table .head span {
    font-size: 1rem;
  }
}
.page-price .premise-table .body {
  background-color: #fff;
  font-size: 1.5rem;
  font-weight: 700;
  padding: 36px 0 30px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table .body {
    font-size: 1.1rem;
    padding: 24px 0 17px;
  }
}
.page-price .premise-table .body span {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 4.2rem;
  color: #3c7be3;
  display: inline-block;
  margin-right: 2px;
}
.page-price .premise-table .body span else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table .body span {
    font-size: 3rem;
  }
}
.page-price .premise-table .body .note {
  font-size: 1.2rem;
  margin-top: 22px;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table .body .note {
    font-size: 1rem;
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .page-price .premise-table + .premise-table {
    margin-top: 15px;
  }
}
.page-price .premise-table + .premise-table .head {
  border-left: 2px solid #fff;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table + .premise-table .head {
    border: none;
  }
}
.page-price .premise-table + .premise-table .body {
  border-left: 2px solid #ccc;
}
@media screen and (max-width: 768px) {
  .page-price .premise-table + .premise-table .body {
    border: none;
  }
}
.page-price .cloud-table {
  width: 100%;
  border-collapse: collapse;
  background-color: #f5f5f5;
  margin-top: 40px;
  min-width: 1020px;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table {
    margin-top: 15px;
  }
}
.page-price .cloud-table tr,
.page-price .cloud-table th,
.page-price .cloud-table td {
  vertical-align: middle;
  text-align: center;
}
.page-price .cloud-table thead tr {
  background-color: #3c7be3;
}
.page-price .cloud-table thead tr td {
  color: #fff;
  padding: 15px 10px;
}
.page-price .cloud-table thead tr td .lead {
  font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table thead tr td .lead {
    font-size: 1rem;
    line-height: 1.6rem;
  }
}
.page-price .cloud-table thead tr td .name {
  font-size: 2.1rem;
  font-weight: 700;
  margin-top: 10px;
  line-height: 2.5rem;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table thead tr td .name {
    margin-top: 5px;
    font-size: 1.6rem;
    line-height: 1.8rem;
  }
}
.page-price .cloud-table thead tr td .name span {
  font-size: 1.4rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table thead tr td {
    padding: 8px 10px;
    font-size: 1.4rem;
    line-height: 1.7857142857em;
    letter-spacing: 0em;
  }
}
.page-price .cloud-table thead tr td + td {
  border-left: 2px solid #fff;
}
.page-price .cloud-table thead tr td:nth-child(n+2) {
  width: 18.627%;
}
.page-price .cloud-table tbody td {
  color: #111;
  padding: 26px 10px;
  font-weight: 500;
  background-color: #fff;
  font-size: 1.3rem;
  line-height: 1.5384615385em;
  letter-spacing: 0em;
}
.page-price .cloud-table tbody td:not(:first-child) {
  border-left: 2px solid #ccc;
}
.page-price .cloud-table tbody td:not(:first-child), .page-price .cloud-table tbody td:not(:nth-child(2)) {
  border-bottom: 2px solid #ccc;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table tbody td {
    padding: 6px 8px;
    font-size: 1.1rem;
    line-height: 1.4545454545em;
    letter-spacing: 0em;
  }
}
.page-price .cloud-table tbody td.price {
  font-size: 1.2rem;
  font-weight: 700;
  padding: 20px 10px;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table tbody td.price {
    font-size: 1rem;
    padding: 10px 5px;
  }
}
.page-price .cloud-table tbody td.price span {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 2.8rem;
  color: #3c7be3;
  margin: 2px 5px 0;
}
.page-price .cloud-table tbody td.price span else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table tbody td.price span {
    font-size: 2rem;
  }
}
.page-price .cloud-table tbody td span {
  display: inline-block;
  text-align: left;
  font-size: 1.2rem;
  line-height: 1.75em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table tbody td span {
    font-size: 1rem;
    line-height: 1.6em;
    letter-spacing: 0em;
  }
}
.page-price .cloud-table tbody td .product {
  text-align: center;
  font-size: 1.8rem;
  line-height: 2rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-price .cloud-table tbody td .product {
    font-size: 1.5rem;
  }
}
.page-price .cloud-table tbody td i {
  display: inline-block;
  width: 27px;
  height: 26px;
  background: url(../../img/price/checkbox@2x.png) center/contain no-repeat;
}
.page-price .cloud-table tbody tr:nth-child(2) td:first-child {
  background-color: #bfbfbf;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
}
.page-price .cloud-table tbody tr:nth-child(1) td:nth-child(1),
.page-price .cloud-table tbody tr:nth-child(2) td:nth-child(2),
.page-price .cloud-table tbody tr:nth-child(3) td:nth-child(1),
.page-price .cloud-table tbody tr:nth-child(4) td:nth-child(1),
.page-price .cloud-table tbody tr:nth-child(5) td:first-child {
  background-color: #dcdcdc;
  position: relative;
}
.page-price .cloud-table tbody tr:nth-child(1) td:nth-child(1)::after,
.page-price .cloud-table tbody tr:nth-child(2) td:nth-child(2)::after,
.page-price .cloud-table tbody tr:nth-child(3) td:nth-child(1)::after,
.page-price .cloud-table tbody tr:nth-child(4) td:nth-child(1)::after,
.page-price .cloud-table tbody tr:nth-child(5) td:first-child::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: #fff;
  position: absolute;
  bottom: -2px;
  left: 0;
}
.page-price .cloud-table tbody tr:nth-child(5) td:first-child {
  border-top: 2px solid #fff;
}
.page-price .cloud-table tbody tr:nth-child(6) td {
  border-bottom: none;
}
.page-price .cloud-table tbody tr:nth-child(6) td:first-child {
  background-color: #dcdcdc;
}
.page-price .dr-sum {
  text-align: center;
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum {
    margin-top: 37px;
  }
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .logo {
    width: 179px;
    margin: 0 auto;
  }
}
.page-price .dr-sum .title {
  font-size: 2.4rem;
  line-height: 3.7rem;
  font-weight: 700;
  margin-top: 23px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .title {
    font-size: 1.6rem;
    line-height: 2.4rem;
    text-align: left;
    margin-top: 15px;
  }
}
.page-price .dr-sum .detail {
  background-color: #fff;
  padding: 35px 0;
  margin-top: 35px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail {
    padding: 20px 15px;
    margin-top: 15px;
  }
}
.page-price .dr-sum .detail .desc {
  font-size: 1.4rem;
  line-height: 2.6rem;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail .desc {
    text-align: left;
    font-size: 1.2rem;
    line-height: 2rem;
  }
}
.page-price .dr-sum .detail ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 35px;
  position: relative;
  left: 25px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: static;
    margin-top: 15px;
  }
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.drsc .pic {
    width: 106px;
    margin: auto;
  }
}
.page-price .dr-sum .detail ul li.drsc .name {
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.drsc .name {
    margin-top: 10px;
  }
}
.page-price .dr-sum .detail ul li.drsc .price {
  margin-top: 35px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.drsc .price {
    margin-top: 18px;
  }
}
.page-price .dr-sum .detail ul li.drsc .price span {
  color: #b70f5c;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.mbc .pic {
    width: 120px;
    margin: auto;
  }
}
.page-price .dr-sum .detail ul li.mbc .name {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.mbc .name {
    margin-top: 13px;
  }
}
.page-price .dr-sum .detail ul li.mbc .price span {
  color: #3c7be3;
}
.page-price .dr-sum .detail ul li.plus {
  width: 41px;
  -ms-flex-item-align: center;
      align-self: center;
  margin: 0 60px;
  position: relative;
  top: -66px;
  left: 6px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li.plus {
    position: static;
    width: 30px;
    margin: 15px 0;
  }
}
.page-price .dr-sum .detail ul li .name {
  font-size: 2rem;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li .name {
    font-size: 1.6rem;
  }
}
.page-price .dr-sum .detail ul li .name span {
  font-size: 1.4rem;
  font-weight: 700;
  display: inline-block;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li .name span {
    font-size: 1.2rem;
  }
}
.page-price .dr-sum .detail ul li .price {
  font-size: 1.4rem;
  font-weight: 700;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li .price {
    font-size: 1.2rem;
    margin-top: 15px;
  }
}
.page-price .dr-sum .detail ul li .price span {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 2.6rem;
  display: inline-block;
  margin: 0 4px;
}
.page-price .dr-sum .detail ul li .price span else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li .price span {
    font-size: 2.2rem;
  }
}
.page-price .dr-sum .detail ul li .note {
  margin-top: 15px;
  font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
  .page-price .dr-sum .detail ul li .note {
    font-size: 1rem;
    margin-top: 8px;
  }
}
.page-price .price-license {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-price .price-license {
    margin-bottom: 40px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-price .price-license > div {
  width: 35%;
  padding: 38px 25px;
  background-color: #ebf2fc;
}
.page-price .price-license > div:last-child {
  width: 62%;
}
.page-price .price-license .flbox {
  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;
}
.page-price .price-license .flbox dl {
  width: 48%;
}
.page-price .price-license dl {
  border: 2px solid #3c7be3;
  background: #fff;
  padding-bottom: 20px;
}
.page-price .price-license dt {
  font-weight: bold;
  color: #3c7be3;
  text-align: center;
  background: #f1f6fd;
  padding: 10px 0;
  font-size: 1.4rem;
  line-height: 1.3;
}
@media screen and (max-width: 768px) {
  .page-price .price-license > div {
    width: 100% !important;
    padding: 29px 25px;
  }
  .page-price .price-license .flbox dl {
    width: 100%;
  }
  .page-price .price-license .flbox dl + dl {
    margin-top: 15px;
  }
  .page-price .price-license div:not(:last-child) {
    margin-bottom: 15px;
  }
}
.page-price .price-license h4 {
  text-align: center;
  font-weight: 700;
  color: #3c7be3;
  font-size: 2.2rem;
  line-height: 1em;
  letter-spacing: 0em;
  padding-bottom: 25px;
  border-bottom: 2px solid #b6cef4;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license h4 {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 15px;
    padding-bottom: 15px;
  }
}
.page-price .price-license-list {
  min-height: 160px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-list {
    min-height: auto;
    margin-bottom: 16px;
  }
}
.page-price .price-license-list li {
  position: relative;
  padding-left: 1em;
  font-size: 1.5rem;
  line-height: 1.8em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-list li {
    font-size: 1.2rem;
    line-height: 1.6666666667em;
    letter-spacing: 0em;
  }
}
.page-price .price-license-list li::before {
  content: "";
  width: 7px;
  height: 7px;
  background-color: #3c7be3;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 12px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-list li::before {
    width: 5px;
    height: 5px;
    top: 9px;
  }
}
.page-price .price-license figure {
  margin: 20px auto 32px;
  max-width: 280px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license figure {
    width: 91.6666666667%;
    margin-bottom: 20px;
  }
}
.page-price .price-license div:last-child figure {
  max-width: 302px;
}
.page-price .price-license-label {
  text-align: center;
  font-size: 1.2rem;
  margin: 10px 0 8px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-label {
    font-size: 1.1rem;
    line-height: 1.9230769231em;
    letter-spacing: 0em;
    margin-bottom: 5px;
  }
}
.page-price .price-license-cost {
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-cost {
    margin: 0 -15px 8px;
  }
}
.page-price .price-license-cost i {
  color: #3c7be3;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 3rem;
  line-height: 1em;
  letter-spacing: 0em;
  display: inline-block;
  padding: 0 5px;
}
.page-price .price-license-cost i else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-cost i {
    font-size: 3rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-price .price-license-cost span {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.3333333333em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-cost span {
    font-size: 1.1rem;
    line-height: 1.8181818182em;
    letter-spacing: 0em;
  }
}
.page-price .price-license-note {
  text-align: center;
  font-size: 1.2rem;
  line-height: 1em;
  letter-spacing: 0em;
}
@media screen and (max-width: 768px) {
  .page-price .price-license-note {
    font-size: 1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-price .price03 {
  padding: 90px 0 120px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-price .price03 {
    padding: 40px 0 80px;
  }
}
.page-price .price03 .price-title {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 768px) {
  .page-price .price03 .price-title {
    text-align: left;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.page-price .price03 .price-text {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-price .price03 .price-text {
    margin-top: 15px;
  }
}
.page-price .price03 .button-wrap {
  margin: 65px auto 0;
}
@media screen and (max-width: 768px) {
  .page-price .price03 .button-wrap {
    margin: 25px auto 0;
  }
  .page-price .price03 .button-wrap a {
    width: 240px;
  }
}

.page-scene {
  padding-bottom: 0;
}
.page-scene .hero {
  background: url(../../img/price/hero_bg_pc.png) center top/cover no-repeat;
}
@media screen and (max-width: 768px) {
  .page-scene .hero {
    background: url(../../img/price/hero_bg_sp.png) center top/cover no-repeat;
  }
}
/* 共通CTA */
.page-scene .info {
  position: relative;
}
.page-scene .info::before {
  content: "";
  background-color: #3C7BE3;
  width: 100vw;
  height: 100%;
  position: absolute;
  z-index: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.page-scene .info .section-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  justify-content: center;
  flex-direction: column;
  position: relative;
  z-index: 1;
  height: 240px;
}
@media screen and (max-width: 768px) {
  .page-scene .info .section-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
    padding: 20px 0 25px;
  }
}
.page-scene .info .heading {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 4rem;
  margin-left: 55px;
  white-space: nowrap;
  letter-spacing: 0.04em;
  color: #fff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-scene .info .heading {
    text-align: center;
    font-size: 1.9rem;
    margin: 0 auto;
    line-height: 2.9rem;
  }
}
.page-scene .info .heading::before,
.page-scene .info .heading::after {
  position: relative;
  display: inline-block;
  content: "";
  background: #fff;
  width: 2px;
  height: 29px;
  margin: 0 1em;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .page-scene .info .heading::before,
  .page-scene .info .heading::after {
    content: none;
  }
}
.page-scene .info .heading::before {
  transform: rotate(-45deg);
}
.page-scene .info .heading::after {
  transform: rotate(45deg);
}
.page-scene .info .button-wrap {
  margin-top: 20px;
  display: flex;
  gap: 20px;
}
@media screen and (max-width: 1057px) {
  .page-scene .info .button-wrap {
    margin-top: 15px;
    gap: 10px;
  }
}
@media screen and (max-width: 768px) {
  .page-scene .info .button-wrap {
    margin: 15px auto 0;
  }
}
.page-scene .info .button-wrap a {
  width: 360px;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .page-scene .info .button-wrap a {
    width: 220px;
    margin: 0 auto;
  }
}
.page-scene .info .button-wrap a span {
  font-size: 1.6rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-scene .info .button-wrap a span {
    font-size: 1.3rem;
  }
}
.page-scene .info .button-wrap .red-btn {
  background-color: #b40200;
}
.page-scene .info .button-wrap .white-btn {
  background-color: #fff;
}
.page-scene .info .button-wrap .white-btn span {
  color: #000;
}
.page-scene .info .button-wrap .red-btn::after,
.page-scene .info .button-wrap .white-btn::after {
  border-width: 7px 0 7px 12.1px;
}
.page-scene .info .button-wrap .white-btn::after {
  border-left-color: #000;
}
@media screen and (max-width: 768px) {
  .page-scene .info .button-wrap .red-btn::after,
  .page-scene .info .button-wrap .white-btn::after {
    border-width: 4px 0 4px 6.9px;
  }
}
.page-scene .bg-gray {
  background: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
.page-scene .bg-blue {
  background: #3c7be3;
  margin: 0 calc(50% - 50vw);
  padding: 20px calc(50vw - 50%);
}
.page-scene .bg-darkgray {
  background: #4B4346;
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
.page-scene .bg-blue .scene-area-title,
.page-scene .bg-darkgray .scene-area-title {
  color: #fff;
}
.page-scene .bg-darkgray .scene-area-title {
  padding: 120px 0 140px;
  margin: 0;
  font-size: 4rem;
}
@media screen and (max-width: 768px) {
  .page-scene .bg-darkgray .scene-area-title {
    padding: 70px 0 120px;
    font-size: 2.7rem;
  }
}
.page-scene .bg-white {
  background: #FFFFFF;
  margin: 0 calc(50% - 50vw);
  padding: 20px calc(50vw - 50%);
}

.page-scene .scene-area-title {
  font-size: 3.2rem;
  text-align: center;
  font-weight: bold;
  margin: 40px 0;
}
@media screen and (max-width: 768px) {
  .page-scene .scene-area-title .scene-area-title {
    font-size: 2.4rem;
    margin: 20px 0;
  }
}
.page-scene .scene-box {
  padding: 80px 0 120px;
  max-width: 950px;
  margin: 0 auto;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  .page-scene .scene-box {
    padding: 40px 0;
    font-size: 1.3rem;
  }
}
.page-scene .scene-box .scene-box-label {
  margin-bottom: 24px;
  display: flex;
  gap: 10px;
}
@media screen and (max-width: 768px) {
  .page-scene .scene-box .scene-box-label {
    margin-bottom: 10px;
  }
}
.page-scene .scene-box .scene-box-label span {
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: bold;
  color: #3C7BE3;
  background-color: #EDF4FD;
  display: inline-block;
  padding: 5px 10px;
}
@media screen and (max-width: 768px) {
  .page-scene .scene-box .scene-box-label span {
    font-size: 1.2rem;
    padding: 8px 10px;
  }
}
.page-scene .scene-box h2 {
  font-weight: bold;
  font-size: 3.2rem;
  padding-bottom: 25px;
  margin-bottom: 40px;
  position: relative;
  line-height: 1.45;
}
@media screen and (max-width: 768px) {
  .page-scene .scene-box h2 {
    font-size: 2.2rem;
    margin-bottom: 30px;
    padding-bottom: 20px;
  }
  .page-scene .scene-box h2::after {
    width: 7%;
  }
}
.page-scene .scene-box h2::before {
  content: "";
  position: absolute;
  display: block;
  height: 3px;
  background: #e5e5e5;
  left: 0;
  bottom: 0;
  width: 100%;
}
.page-scene .scene-box h2::after {
  content: "";
  position: absolute;
  display: block;
  height: 3px;
  background: #e5e5e5;
  left: 0;
  bottom: 0;
  width: 100%;
  width: 34px;
  background: #3c7be3;
}
.page-scene .scene-box:not(:has(.case-content)) .fix {
  margin-bottom: 0;
}
/* .page-scene .problem {
  padding-bottom: 65px;
  margin-bottom: 20px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-scene .problem {
    padding-bottom: 45px;
    margin-bottom: 15px;
  }
}
.page-scene .problem::before,
.page-scene .problem::after {
  content: "";
  position: absolute;
  display: block;
  left: 50%;
  transform: translateX(-50%);
}
.page-scene .problem::before { 
  width: 3px;
  height: 35px;
  bottom: 16px;
  background-color: #7C7C7C;
}
@media screen and (max-width: 768px) {
  .page-scene .problem::before { 
    width: 3px;
    height: 28px;
    bottom: 10px;
  }
}
.page-scene .problem::after {
  border-style: solid;
  border-width: 18px 14px 0 14px;
  border-color: #7C7C7C transparent transparent transparent;
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .page-scene .problem::after {
    border-width: 12px 9px 0 9px;
  }
}
.page-scene .problem dl {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 40px 65px;
  background: #E5E5E5;
}
@media screen and (max-width: 768px) {
  .page-scene .problem dl {
    padding: 30px 20px;
  }
}
.page-scene .problem dt {
  font-weight: bold;
  font-size: 2.5rem;
  line-height: 1.5;
  color: #fff;
  background-color: #3C7BE3;
  text-align: center;
  padding: 2px 12px;
}
@media screen and (max-width: 768px) {
  .page-scene .problem dt {
    font-size: 1.8rem;
  }
}
.page-scene .problem dd {
  font-size: 2rem;
  line-height: 1.8;
  margin-top: 20px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-scene .problem dd {
    font-size: 1.5rem;
    line-height: 1.6;
  }
}
.page-scene .problem dd span {
  color: #3c7be3;
  font-weight: bold;
} */

.page-scene .problem {
  background: #ececec;
  padding: 25px 0;
  margin-bottom: 20px;
}

.page-scene .bg-gray .problem {
  background: #e2e1e1;
}

.page-scene .problem dl {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}

.page-scene .problem dt {
  font-weight: bold;
  font-size: 2.2rem;
  color: #3c7be3;
  width: 165px;
  text-align: center;
  flex-shrink: 0;
}

.page-scene .problem dd {
  flex: 1;
  line-height: 1.8;
  padding-left: 45px;
  padding-right: 20px;
  border-left: 1px solid #b6b6b6;
}

.page-scene .problem .l-single {
  padding: 0.8em 0 0.8em 45px;
}

.page-scene .problem dd span {
  color: #3c7be3;
}

@media screen and (max-width: 768px) {
  .page-scene .problem {
    padding: 30px 25px;
  }
  
  .page-scene .problem dt {
    width: 100%;
    font-size: 1.6rem;
  }
  
  .page-scene .problem dd {
    border: none;
    border-top: 1px solid #b6b6b6;
    padding: 15px 0 0 0;
    margin-top: 20px;
    font-size: 1.2rem;
    line-height: 1.6;
  }
  
  .page-scene .problem .l-single {
    padding: 15px 0 0 0;
  }
}

/* .page-scene .fix {
  margin-bottom: 100px;
  padding-top: 58px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-scene .fix {
    padding-top: 40px;
    margin-bottom: 30px;
  }
}
.page-scene .fix::before {
  content: "解決";
  color: #fff;
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 115px;
  height: 115px;
  background-color: #3c7be3;
  border-radius: 100%;
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .page-scene .fix::before {
    width: 76px;
    height: 76px;
    font-size: 1.8rem;
  }
}
.page-scene .fix .fix-wrap {
  border: 3px solid #3c7be3;
  padding: 85px 120px 48px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-scene .fix .fix-wrap {
    padding: 49px 25px 30px;
  }
}
.page-scene .fix .fix-wrap::before {
  content: "";
  display: block;
  width: calc(100% - 14px);
  height: calc(100% - 14px);
  inset: 0;
  margin: auto;
  background-color: #F7FAFF;
  position: absolute;
}
.page-scene .fix .fix-wrap > * {
  position: relative;
  z-index: 1;
}
.page-scene .fix dl {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.page-scene .fix dt {
  font-weight: bold;
  color: #000000;
  font-size: 2.2rem;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dt {
    font-size: 1.6rem;
  }
}
.page-scene .fix dt::before,
.page-scene .fix dt::after {
  position: relative;
  display: inline-block;
  content: "";
  background: #000000;
  width: 2px;
  height: 29px;
  margin: 0 1em;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dt::before,
  .page-scene .fix dt::after {
    height: 18px;
  }
}
.page-scene .fix dt::before {
  transform: rotate(-45deg);
}
.page-scene .fix dt::after {
  transform: rotate(45deg);
}
.page-scene .fix dd {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd {
    margin-top: 15px;
  }
}
.page-scene .fix dd > *:not(:first-child) {
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd > *:not(:first-child) {
    margin-top: 20px;
  }
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-list {
    text-align: left;
  }
}
.page-scene .fix dd .fix-list li {
  font-weight: bold;
  font-size: 2.2rem;
  line-height: 1.6;
  color: #3c7be3;
  text-decoration: underline;
  text-underline-offset: 8px;
  position: relative;
  padding-left: 1em;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-list li {
    font-size: 1.6rem;
    text-underline-offset: 4px;
    text-decoration-thickness: 2px;
  }
}
.page-scene .fix dd .fix-list li::before {
  content: "・";
  position: absolute;
  left: 0;
}
.page-scene .fix dd .fix-list li + li {
  margin-top: 15px;
}
.page-scene .fix dd .fix-text {
  font-size: 1.6rem;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-text {
    font-size: 1.3rem;
  }
}
.page-scene .fix dd .fix-box {
  background-color: #fff;
  padding: 20px 20px 30px;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-box {
    padding: 20px 15px;
  }
}
.page-scene .fix dd .fix-box p {
  background-color: #3c7be3;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.6;
  font-weight: bold;
  display: inline-block;
  padding: 5px 10px;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-box p {
    font-size: 1.3rem;
    padding: 3px 8px;
  }
}
.page-scene .fix dd .fix-box ul {
  text-align: left;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-box ul {
    margin-top: 20px;
  }
}
.page-scene .fix dd .fix-box ul li {
  position: relative;
  padding-left: 1em;
  font-size: 1.6rem;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-box ul li {
    font-size: 1.3rem;
  }
}
.page-scene .fix dd .fix-box ul li::before {
  content: "・";
  position: absolute;
  left: 0;
}
@media screen and (max-width: 768px) {
  .page-scene .fix dd .fix-box ul li + li {
    margin-top: 20px;
  }
}
.page-scene .fix figure {
  width: 49%;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .page-scene .fix figure {
    width: 100% !important;
    margin-top: 25px;
  }
}
.page-scene .fix figure img {
  width: 100%;
} */

.fix {
  border: 1px solid #3c7be3;
  padding: 35px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 100px;
}
.fix dl {
  width: 55%;
}
.fix dt {
  font-weight: bold;
  color: #3c7be3;
  font-size: 2.4rem;
  margin: 0 0 30px;
}
.fix dd {
  font-weight: bold;
  line-height: 2;
}
.fix dd span {
  font-weight: bold;
  color: #3c7be3;
  background: #ebf2fc;
}
.fix figure {
  width: 44%;
  text-align: center;
}
.fix.column-01 {
  flex-direction: column;
}
.fix.column-01 dl,
.fix.column-01 figure {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .page-scene .fix {
    padding: 30px 20px;
    margin-bottom: 30px;
  }
  
  .page-scene .fix dl {
    width: 100% !important;
  }
  
  .page-scene .fix dt {
    text-align: center;
    font-size: 1.6rem;
    margin-bottom: 25px;
  }
  
  .page-scene .fix dd {
    line-height: 1.7;
  }
  
  .page-scene .fix figure {
    width: 100% !important;
    margin-top: 25px;
  }
}


.page-scene .case-item-data {
  font-size: 1.3rem;
}
@media screen and (max-width: 768px) {
  .page-scene .case-item-data {
    font-size: 1.1rem;
  }
}
.page-scene .scene03,
.page-scene .scene02 {
  background-color: #fff;
  margin-top: -75px;
  padding: 80px 120px 120px;
  max-width: 1190px;
}
@media screen and (max-width: 768px) {
  .page-scene .scene03,
  .page-scene .scene02 {
    margin-top: -60px;
    padding: 35px 8px 40px;
    margin-left: -8px;
    margin-right: -8px;
  }
}
.page-scene .scene03 .g-model p {
  text-align: center;
  margin: 70px 0 50px;
  line-height: 1.5;
  font-size: 2.5rem;
}
@media screen and (max-width: 768px) {
  .page-scene .scene03 .g-model p {
    margin: 35px 0 25px;
    font-size: 1.8rem;
  }
}
.page-scene .scene03 .g-model p span {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #f9e5ef));
  background: linear-gradient(transparent 60%, #f9e5ef 60%);
  font-weight: bold;
}
.page-scene .scene03 .button-wrap.button-border a {
  width: 100%;
  max-width: 460px;
}
@media screen and (max-width: 768px) {
  .page-scene .scene03 .button-wrap.button-border a {
    max-width: 220px;
  }
}
/* .page-scene .scene05 .special {
  width: 100%;
  margin-top: 35px;
  padding-top: 35px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: url(/product/dr_sum/img/scene/bg_line.png) 0 0 repeat-x;
}
@media screen and (max-width: 768px) {
  .page-scene .scene05 .special {
    margin-top: 20px;
    padding-top: 20px;
  }
}
.page-scene .scene05 .special figure {
  max-width: 218px;
  margin-right: 20px;
}
@media screen and (max-width: 768px) {
  .page-scene .scene05 .special figure {
    max-width: none;
    width: 80% !important;
    margin: 0 auto 20px;
  }
}
.page-scene .scene05 .special a {
  position: relative;
  font-weight: bold;
  color: #c40161;
  border-bottom: 1px solid #c40161;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding-bottom: 8px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.page-scene .scene05 .special a::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  margin-top: 3px;
  border-top: 1px solid #c40161;
  border-right: 1px solid #c40161;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-left: 3px;
} */
.page-scene .case-content {
  max-width: 950px;
  margin: 0 auto;
}
.page-scene .case-content .case-study {
  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;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-study {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-scene .case-content .case-item {
  width: 31%;
  background-color: #fff;
  padding-bottom: 25px;
  -webkit-box-shadow: 0 0 26px rgba(49, 60, 71, 0.12);
          box-shadow: 0 0 26px rgba(49, 60, 71, 0.12);
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item {
    width: 100%;
    -webkit-box-shadow: 0 0 13px rgba(49, 60, 71, 0.12);
            box-shadow: 0 0 13px rgba(49, 60, 71, 0.12);
  }
}
.page-scene .case-content .case-item + .case-item {
  margin-left: 3%;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item + .case-item {
    margin-left: 0;
  }
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item:not(:last-child) {
    margin-bottom: 25px;
  }
}
.page-scene .case-content .case-item .case-item-label01,
.page-scene .case-content .case-item .case-item-label02 {
  line-height: 1.5;
  font-weight: bold;
  text-align: center;
  padding: 7px 10px;
}
.page-scene .case-content .case-item .case-item-label01 {
  color: #3C7BE3;
  background: #E0E6F0;
}
.page-scene .case-content .case-item .case-item-label02 {
  color: #FFFFFF;
  background: #3C7BE3;
}
.page-scene .case-content .case-item .case-item-text {
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  padding: 20px 15px 4px;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item .case-item-text {
    padding: 20px 15px 4px;
    justify-content: flex-start;
  }
}
.page-scene .case-content .case-item .case-item-text h3 {
  text-align: center;
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.6666666667em;
  letter-spacing: 0.01em;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item .case-item-text h3 {
    text-align: left;
    font-size: 1.6rem;
    line-height: 1.4375em;
    letter-spacing: 0em;
    min-height: auto;
  }
}
.page-scene .case-content .case-item .case-item-data {
  padding: 7px 5px;
  background-color: #eff0f0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 17px;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item .case-item-data {
    font-size: 1.1rem;
    line-height: 1.9090909091em;
    letter-spacing: 0em;
  }
}
.page-scene .case-content .case-item .case-item-logo {
  text-align: center;
  margin: 10px 0 15px;
  padding: 0 15px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.page-scene .case-content .case-item .case-item-link {
  text-align: center;
}
.page-scene .case-content .case-item .case-item-link a {
  color: #3c7be3;
  display: inline-block;
  padding: 0 5px 5px;
  border-bottom: 2px solid #3c7be3;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.page-scene .case-content .case-item .case-item-link a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item .case-item-link a {
    padding: 8px 5px 8px;
  }
}
.page-scene .case-content .case-item .case-item-link a span {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 2.1333333333em;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 768px) {
  .page-scene .case-content .case-item .case-item-link a span {
    font-size: 1.2rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}
.page-scene .case-content .case-item .case-item-link a span::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8.7px;
  border-color: transparent transparent transparent #3c7be3;
  margin-left: 10px;
}
.page-scene .case-content .case-item > figure img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.page-scene .nest {
  position: relative;
  padding-top: 60px;
  padding-bottom: 60px;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.page-scene .nest .nest-bnr-image {
  max-width: 60%;
}
@media screen and (max-width: 768px) {
  .page-scene .nest .nest-bnr-image {
    max-width: 90%;
  }
}

.page-scene .nest a:hover{
  opacity: 0.6;
  transition: all 0.3s;
}

.page-scene .contact {
  background: url(../../img/scene/contact_bg.png) center top/cover no-repeat;
  margin: 0 calc(50% - 50vw);
  padding: 60px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .page-scene .contact {
    background: url(../../img/scene/contact_bg_sp.png) center top/cover no-repeat;
    padding: 40px 30px;
  }
}
.page-scene .contact-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1060px) {
  .page-scene .contact-list {
    -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;
  }
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-scene .contact-list li {
  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;
  text-align: center;
  width: 29.0434782609%;
  background-color: #fff;
  padding: 37px 0 49px;
}
@media screen and (max-width: 1060px) {
  .page-scene .contact-list li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.page-scene .contact-list li + li {
  margin-left: 2.7826086957%;
}
@media screen and (max-width: 1060px) {
  .page-scene .contact-list li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
.page-scene .contact-list li:nth-child(1) figure {
  width: 41px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li:nth-child(1) figure {
    width: 31.5px;
  }
}
.page-scene .contact-list li:nth-child(2) figure {
  width: 47px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li:nth-child(2) figure {
    width: 40.5px;
  }
}
.page-scene .contact-list li:nth-child(3) figure {
  width: 54px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li:nth-child(3) figure {
    width: 45.5px;
  }
}
.page-scene .contact-list li figure {
  min-height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 14px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li figure {
    min-height: 45px;
    margin-bottom: 15px;
  }
}
.page-scene .contact-list li p {
  text-align: center;
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0.025em;
  font-weight: 400;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-list li p {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.page-scene .contact-button {
  margin-top: auto;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-button {
    height: auto;
  }
}
.page-scene .contact-button a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #3c7be3;
  color: #fff;
  width: 276px;
  min-height: 50px;
  font-size: 14px;
  font-weight: 500;
  padding: 18px 30px;
  border-radius: 25px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-button a {
    width: 190px;
    min-height: 31px;
    padding: 8px 15px 8px;
    border-radius: 31px;
  }
}
.page-scene .contact-button a::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: 1px;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .page-scene .contact-button a::after {
    right: 10px;
    border-width: 4px 0 4px 5px;
  }
}
@media (hover: hover) {
  .page-scene .contact-button a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .page-scene .contact-button a:hover {
    opacity: 0.7;
  }
}
.page-scene .contact-button a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1em;
  letter-spacing: 0em;
  display: inline-block;
  padding-bottom: 1px;
}
@media screen and (max-width: 768px) {
  .page-scene .contact-button a span {
    font-size: 1.1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}

.scene-anchor {
  margin: 0 calc(50% - 50vw);
  padding: 80px calc(50vw - 50%);
  background: #f3f2f2;
}

.scene-anchor-inner {
  max-width: 950px;
  margin: 0 auto;
}

.scene-anchor-inner > :first-child {
  margin-top: 0;
}

.heading-anchor {
font-size: 22px;
font-weight: bold;
padding-left: 15px;
border-left: 4px solid #3c7be3;
margin: 60px 0 24px;
line-height: 1.2;
}

.anchor-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.anchor-link {
  background: #fff;
  transition: opacity 0.3s;
  display: grid;
  grid-template-columns: 70px auto;
  gap: 15px;
  padding: 16px;
	padding-right: 40px;
  align-items: center;
  position: relative;
}

.anchor-link:hover {
  opacity: 0.7;
}

.anchor-link::after {
  content: "";
  position: absolute;
  display: block;
  right: 24px;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 12px;
  height: 8px;
  border: 6px solid transparent;
  border-top: 8px solid #3c7be3;
}

.anchor-link span{
  font-size: 15px;
  font-weight: bold;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .scene-anchor {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  
  .heading-anchor {
    font-size: 18px;
    margin: 30px 0 16px;
  }
  
  .anchor-list {
    display: block;
  }
  
  .anchor-item + .anchor-item {
    margin-top: 10px;
  }

  .anchor-link {
    grid-template-columns: 56px auto;
    padding: 12px;
    padding-right: 40px;
  }
  
  .anchor-link span{
    font-size: 13px;
  }
}






.demo {
  padding-bottom: 0;
  max-width: 1250px;
}
.demo .--module_heroContent {
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .demo .--module_heroContent {
    padding: 26px 15px 33px;
  }
}
.demo .--module_sectionContent {
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .demo .--module_sectionContent {
    padding: 0;
  }
}
.demo .--module_text01 {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .demo .--module_text01 {
    font-size: 12px;
  }
}
.demo .--module_text02 {
  font-size: 20px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .demo .--module_text02 {
    font-size: 14px;
  }
}
.demo .--module_tag01 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
}
.demo .--module_tag01 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .demo .--module_tag01 {
    font-size: 10px;
  }
}
.demo .--module_tag02 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.03em;
}
.demo .--module_tag02 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .demo .--module_tag02 {
    font-size: 10px;
  }
}
.demo .--module_lead01 {
  font-size: 18px;
  line-height: 1.89;
}
@media screen and (max-width: 768px) {
  .demo .--module_lead01 {
    font-size: 13px;
    line-height: 1.846;
  }
}
.demo .--module_head01 {
  font-size: 36px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .demo .--module_head01 {
    font-size: 20px;
  }
}
.demo .--module_head01.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.demo .--module_head02 {
  font-size: 28px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .demo .--module_head02 {
    font-size: 16px;
  }
}
.demo .--module_head02.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.demo .--module_head03 {
  font-size: 20px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .demo .--module_head03 {
    font-size: 14px;
  }
}
.demo .--module_head04 {
  display: inline-block;
  font-size: 18px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
  color: #6bcbd8;
  border-bottom: 2px solid #6bcbd8;
}
.demo .--module_head04 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .demo .--module_head04 {
    font-size: 10px;
  }
}
.demo .--module_head05 {
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
.demo .--module_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;
  background-color: #000;
  color: #fff;
  min-width: 300px;
  max-width: 320px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
}
.demo .--module_btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.demo .--module_headingBg {
  color: #fff;
  text-align: center;
  height: 184px;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #4b4346;
  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;
}
@media screen and (max-width: 768px) {
  .demo .--module_headingBg {
    height: 127px;
  }
}
.demo .--module_headingBg .--module_head01 {
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .demo .--module_headingBg .--module_head01 {
    margin-top: 4px;
  }
}
.demo .content {
  max-width: 1250px;
}
.demo .--color-blue {
  color: #3c7be3;
}
.demo section.hero {
  width: 100vw;
  background-image: url(../../img/demo/hero-bg.jpg);
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  margin: 0 calc(50% - 50vw);
}
@media screen and (max-width: 768px) {
  .demo section.hero {
    background-image: url(../../img/demo/hero-bg--sp.jpg);
  }
}
.demo section.hero .hero-content {
  padding: 0 20px 0;
  width: 100%;
  max-width: 1520px;
  margin: 0 auto;
  height: 468px;
  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;
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 17px 0 34px 0;
    height: auto;
    position: relative;
  }
}
.demo section.hero .hero-content .textArea {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content .textArea {
    margin-top: 28.5px;
  }
}
.demo section.hero .hero-content .textArea .hero-content__heading span {
  font-size: 48px;
  font-weight: bold;
  line-height: 1.125;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content .textArea .hero-content__heading span {
    font-size: 27px;
  }
}
.demo section.hero .hero-content .textArea .hero-content__text {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content .textArea .hero-content__text {
    font-size: 14px;
    margin-top: 12px;
  }
}
.demo section.hero .hero-content .textArea .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;
  background-color: #c12c1f;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  margin-top: 48px;
}
.demo section.hero .hero-content .textArea .btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content .textArea .btn {
    margin: 0;
    position: absolute;
    bottom: 40px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.demo section.hero .hero-content .imageArea {
  width: 45.0381679389%;
  margin-top: 24px;
  margin-left: 5.8778625954%;
}
@media screen and (max-width: 768px) {
  .demo section.hero .hero-content .imageArea {
    width: 85.9375vw;
    margin-left: 0;
    text-align: center;
  }
}
.demo section.about {
  padding-top: 90px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .demo section.about {
    padding-top: 34px;
    padding-bottom: 50px;
  }
}
.demo section.about .lead {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .demo section.about .lead {
    text-align: left;
  }
}
.demo section.about .lead span {
  font-weight: bold;
}
.demo section.about .box {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 768px) {
  .demo section.about .box {
    margin-top: 18px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.demo section.about .about-btn {
  width: 296px;
  height: 77px;
  margin: 0;
  border-radius: 38.5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn {
    width: 222px;
    height: 56.5px;
    border-radius: 56.5px;
    margin: 0 auto;
  }
}
@media (hover: hover) {
  .demo section.about .about-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo section.about .about-btn:hover {
    opacity: 0.7;
  }
}
.demo section.about .about-btn::before {
  content: "";
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.demo section.about .about-btn.--apply {
  background-color: #3c7be3;
}
.demo section.about .about-btn.--apply::before {
  content: "";
  width: 30px;
  height: 35px;
  left: 35px;
  background-image: url(../../img/demo/icon-apply.svg);
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn.--apply::before {
    width: 22.5px;
    height: 26.5px;
    left: 27px;
  }
}
.demo section.about .about-btn.--demo {
  background-color: #c12c1f;
}
.demo section.about .about-btn.--demo::before {
  content: "";
  width: 33px;
  height: 33px;
  left: 30px;
  background-image: url(../../img/demo/icon-demo.svg);
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn.--demo::before {
    width: 25px;
    height: 25px;
    left: 25px;
  }
}
.demo section.about .about-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.demo section.about .about-btn + .about-btn {
  margin-left: 32px;
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn + .about-btn {
    margin-left: auto;
    margin-top: 16px;
  }
}
.demo section.about .about-btn .wrap {
  width: 100%;
  height: 100%;
  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;
}
.demo section.about .about-btn .about-btn__text {
  color: #fff;
  font-size: 17px;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.08em;
  margin-left: 84px;
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn .about-btn__text {
    font-size: 13px;
    margin-left: 60px;
  }
}
.demo section.about .about-btn .about-btn__text + .about-btn__text {
  margin-top: 6px;
}
.demo section.about .about-btn .about-btn__text.small {
  font-size: 12px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .demo section.about .about-btn .about-btn__text.small {
    font-size: 10px;
  }
}
.demo section.steps .content {
  padding-top: 100px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content {
    padding-top: 40px;
    padding-bottom: 50px;
  }
}
.demo section.steps .content .block {
  width: 100%;
  padding: 90px 7.8260869565% 84px;
  background-color: #fff;
  -webkit-box-shadow: rgba(0, 0, 0, 0.05) 0 0 32px;
          box-shadow: rgba(0, 0, 0, 0.05) 0 0 32px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .block {
    padding: 15px 15px 35px 15px;
  }
}
.demo section.steps .content .step-flow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.demo section.steps .content .step-flow__item {
  width: 32.9896907216%;
  padding: 0 10px;
  min-height: 230px;
  background-color: #ebf2fc;
  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;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item {
    width: 100%;
    min-height: 190px;
  }
}
.demo section.steps .content .step-flow__item + .step-flow__item {
  margin-left: 4px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item + .step-flow__item {
    margin-top: 4px;
    margin-left: 0;
  }
  .demo section.steps .content .step-flow__item + .step-flow__item .tag {
    margin-top: 28px;
  }
}
.demo section.steps .content .step-flow__item + .step-flow__item::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 0 18px 17px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item + .step-flow__item::before {
    border-width: 15px 15.5px 0 15.5px;
    border-color: #fff transparent transparent transparent;
    top: -0.5px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
.demo section.steps .content .step-flow__item + .step-flow__item::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 0 18px 17px;
  border-color: transparent transparent transparent #ebf2fc;
  position: absolute;
  top: 50%;
  left: -5px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item + .step-flow__item::after {
    border-width: 15px 15.5px 0 15.5px;
    border-color: #ebf2fc transparent transparent transparent;
    top: -6px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
.demo section.steps .content .step-flow__item .tag {
  color: #fff;
  font-size: 18px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  letter-spacing: -0.01em;
  width: 90px;
  height: 29px;
  background-color: #3c7be3;
  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;
}
.demo section.steps .content .step-flow__item .tag else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .tag {
    margin-top: 20px;
    font-size: 14px;
    width: 70px;
    height: 20.5px;
  }
}
.demo section.steps .content .step-flow__item .text {
  margin-top: 14px;
  min-height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .text {
    margin-top: 9px;
    min-height: auto;
  }
}
.demo section.steps .content .step-flow__item .text span {
  font-size: 20px;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: center;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .text span {
    font-size: 14px;
    line-height: 1.5357142857;
    letter-spacing: 0;
  }
}
.demo section.steps .content .step-flow__item .icon {
  width: 130px;
  height: 100px;
  margin-top: auto;
  margin-bottom: 23px;
  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;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .icon {
    width: auto;
    height: auto;
    margin-bottom: 0;
    margin-top: 22px;
  }
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .icon.--icon01 {
    width: 95px;
  }
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .icon.--icon02 {
    width: 106px;
  }
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .icon.--icon03 {
    width: 95px;
  }
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-flow__item .icon img {
    width: 100%;
  }
}
.demo section.steps .content .step-list {
  margin-top: 50px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list {
    margin-top: 31px;
  }
}
.demo section.steps .content .step-list__item + .step-list__item {
  margin-top: 52px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item + .step-list__item {
    margin-top: 33px;
  }
}
.demo section.steps .content .step-list__item .step-head {
  min-height: 86px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 2px solid #e6e6e6;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-head {
    min-height: auto;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding-bottom: 10px;
  }
}
.demo section.steps .content .step-list__item .step-head::before {
  content: "";
  width: 45px;
  height: 2px;
  background-color: #3c7be3;
  position: absolute;
  bottom: -2px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-head::before {
    width: 23px;
  }
}
.demo section.steps .content .step-list__item .step-num {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  min-width: 104px;
  margin-top: 8px;
}
.demo section.steps .content .step-list__item .step-num else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-num {
    min-width: 60px;
    margin-top: 8px;
  }
}
.demo section.steps .content .step-list__item .step-num__text {
  font-size: 20px;
  letter-spacing: 0.01em;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-num__text {
    font-size: 13px;
  }
}
.demo section.steps .content .step-list__item .step-num__num {
  font-size: 34px;
  margin-left: 2px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-num__num {
    font-size: 21px;
    margin-left: 0;
  }
}
.demo section.steps .content .step-list__item .step-title {
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1.7857142857;
  margin-left: 16px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-title {
    font-size: 16px;
    letter-spacing: 0.02em;
    line-height: 1.5;
    margin-left: 12px;
  }
}
.demo section.steps .content .step-list__item .step-textarea {
  margin-top: 39px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-textarea {
    margin-top: 18px;
  }
}
.demo section.steps .content .step-list__item .step-note {
  font-size: 12px;
  line-height: 1.6666666667;
  letter-spacing: 0.025em;
  margin-top: 24px;
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-note {
    font-size: 10px;
    letter-spacing: 0;
    line-height: 1.4;
    margin-top: 12px;
  }
}
.demo section.steps .content .step-list__item .step-btn {
  margin: 42px 0 0;
  background-color: #3c7be3;
}
@media screen and (max-width: 768px) {
  .demo section.steps .content .step-list__item .step-btn {
    font-size: 13px;
    margin: 18px 0 0;
    width: 100%;
    height: 44px;
    min-width: auto;
    padding: 0;
  }
  .demo section.steps .content .step-list__item .step-btn::after {
    right: 15px;
  }
}
@media (hover: hover) {
  .demo section.steps .content .step-list__item .step-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo section.steps .content .step-list__item .step-btn:hover {
    opacity: 0.7;
  }
}
.demo section.board .content {
  padding-top: 100px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .demo section.board .content {
    padding-top: 36px;
    padding-bottom: 50px;
  }
}
.demo section.board .content-block {
  width: 100%;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo section.board .content-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    background-color: #f7f7f7;
    padding: 10px 5.1724137931% 30px;
  }
}
.demo section.board .content-block + .content-block {
  margin-top: 90px;
}
@media screen and (max-width: 768px) {
  .demo section.board .content-block + .content-block {
    margin-top: 30px;
  }
}
.demo section.board .content-block.--reverse .board-textarea {
  margin-left: auto;
  padding: 48px 4.347826087% 40px 9.0434782609%;
}
@media screen and (max-width: 768px) {
  .demo section.board .content-block.--reverse .board-textarea {
    padding: 0;
  }
}
.demo section.board .content-block.--reverse .board-img {
  right: auto;
  left: 0;
}
.demo section.board .board-textarea {
  width: 59.2173913043%;
  background-color: #f7f7f7;
  padding: 48px 9.0434782609% 40px 4.347826087%;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-textarea {
    width: 100%;
    padding: 0;
  }
}
.demo section.board .board-title {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.25;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (max-width: 768px) {
  .demo section.board .board-title {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    margin-top: 14px;
  }
}
.demo section.board .board-attribute-wrap {
  margin-top: 29px;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-attribute-wrap {
    margin-top: 17px;
  }
}
.demo section.board .board-attribute {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-attribute {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.demo section.board .board-attribute + .board-attribute {
  margin-top: 10px;
}
.demo section.board .board-attribute dt {
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  width: 120px;
  height: 26px;
  background-color: #a5a1a2;
  border-radius: 4px;
  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;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-attribute dt {
    font-size: 12px;
    width: 86px;
    height: 21.5px;
    border-radius: 2px;
  }
}
.demo section.board .board-attribute dd {
  font-size: 16px;
  margin-left: 16px;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-attribute dd {
    font-size: 13px;
    line-height: 1.6923076923;
    margin-top: 0;
    margin-left: 14px;
  }
}
.demo section.board .board-text {
  font-size: 14px;
  line-height: 2;
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-text {
    font-size: 12px;
    line-height: 1.875;
    margin-top: 14px;
  }
}
.demo section.board .board-btn-wrap {
  margin-top: 25px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-btn-wrap {
    max-width: 211px;
    margin: 24px auto 0;
  }
}
.demo section.board .board-content-btn {
  width: 100%;
  max-width: 250px;
  min-width: 230px;
  height: 41px;
  margin-left: 0;
  margin-right: 4.5627376426%;
  margin-bottom: 10px;
  padding-bottom: 1px;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-content-btn {
    max-width: 100%;
    min-width: auto;
    width: 211px;
    height: 31px;
    margin: 0 auto 0;
    font-size: 11px;
    padding-bottom: 0;
  }
  .demo section.board .board-content-btn::after {
    right: 12px;
  }
}
@media (hover: hover) {
  .demo section.board .board-content-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo section.board .board-content-btn:hover {
    opacity: 0.7;
  }
}
.demo section.board .board-content-btn + .board-content-btn {
  margin-right: 0;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-content-btn + .board-content-btn {
    margin-right: auto;
    margin-top: 16px;
  }
}
.demo section.board .board-content-btn.--blue {
  background-color: #3c7be3;
}
.demo section.board .board-content-btn.--red {
  background-color: #c12c1f;
}
.demo section.board .board-img {
  width: 45.8260869565%;
  display: block;
  -webkit-box-shadow: rgba(0, 0, 0, 0.04) 0 0 12px;
          box-shadow: rgba(0, 0, 0, 0.04) 0 0 12px;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo section.board .board-img {
    width: 100%;
    position: static;
    -webkit-transform: none;
            transform: none;
    aspect-ratio: 542/349;
  }
}
@media (hover: hover) {
  .demo section.board .board-img {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo section.board .board-img:hover {
    opacity: 0.7;
  }
}
.demo section.board .board-img img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-img img {
    height: 100%;
  }
}
.demo section.board .board-btn {
  width: 338px;
  height: 77px;
  margin: 120px auto 0;
  border-radius: 38.5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-btn {
    width: 250px;
    height: 56.5px;
    margin-top: 52px;
  }
}
.demo section.board .board-btn::before {
  content: "";
  width: 30px;
  height: 35px;
  background-image: url(../../img/demo/icon-apply.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 72px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo section.board .board-btn::before {
    width: 22.5px;
    height: 26.5px;
    left: 55px;
  }
}
.demo section.board .board-btn.--blue {
  background-color: #3c7be3;
}
@media (hover: hover) {
  .demo section.board .board-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo section.board .board-btn:hover {
    opacity: 0.7;
  }
}
.demo section.board .board-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.demo section.board .board-btn .wrap {
  width: 100%;
  height: 100%;
  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;
}
.demo section.board .board-btn .about-btn__text {
  color: #fff;
  font-size: 17px;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.08em;
  margin-left: 120px;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-btn .about-btn__text {
    font-size: 13px;
    margin-left: 91px;
  }
}
.demo section.board .board-btn .about-btn__text + .about-btn__text {
  margin-top: 6px;
}
.demo section.board .board-btn .about-btn__text.small {
  font-size: 12px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .demo section.board .board-btn .about-btn__text.small {
    font-size: 10px;
  }
}
.demo .module-contact {
  background-color: #24b3be;
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 96px 0;
}
@media screen and (max-width: 768px) {
  .demo .module-contact {
    padding: 48px 0;
  }
}
.demo .module-contact::after {
  content: "";
  display: block;
  background-image: url(../../img/demo/module-contact-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center bottom;
  width: 1900px;
  height: 469px;
  position: absolute;
  bottom: -150px;
  left: 50%;
  -webkit-transform: translateX(-50%) rotate(4deg);
          transform: translateX(-50%) rotate(4deg);
}
@media screen and (max-width: 768px) {
  .demo .module-contact::after {
    background-image: url(../../img/demo/module-contact-bg--sp.png);
    width: 888px;
    height: 476px;
    bottom: -75px;
  }
}
.demo .module-contact .module-contact__text {
  font-family: "Noto Sans JP", "Original Yu Gothic", "Yu Gothic", YuGothic, "Hiragino Sans", sans-serif;
  color: #fff;
  text-align: center;
}
.demo .module-contact .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;
  background-color: #fff;
  color: #6bcbd8;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  margin-top: 64px;
}
.demo .module-contact .btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo .module-contact .btn {
    margin-top: 32px;
  }
}
.demo .contact {
  background: url(../../img/demo/contact_bg.png) center top/cover no-repeat;
  margin: 0 calc(50% - 50vw);
  padding: 60px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .demo .contact {
    background: url(../../img/demo/contact_bg_sp.png) center top/cover no-repeat;
    padding: 40px 30px;
  }
}
.demo .contact-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1060px) {
  .demo .contact-list {
    -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;
  }
}
@media screen and (max-width: 768px) {
  .demo .contact-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.demo .contact-list li {
  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;
  text-align: center;
  width: 29.0434782609%;
  background-color: #fff;
  padding: 37px 0 49px;
}
@media screen and (max-width: 1060px) {
  .demo .contact-list li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .demo .contact-list li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.demo .contact-list li + li {
  margin-left: 2.7826086957%;
}
@media screen and (max-width: 1060px) {
  .demo .contact-list li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
.demo .contact-list li:nth-child(1) figure {
  width: 41px;
}
@media screen and (max-width: 768px) {
  .demo .contact-list li:nth-child(1) figure {
    width: 31.5px;
  }
}
.demo .contact-list li:nth-child(2) figure {
  width: 47px;
}
@media screen and (max-width: 768px) {
  .demo .contact-list li:nth-child(2) figure {
    width: 40.5px;
  }
}
.demo .contact-list li:nth-child(3) figure {
  width: 54px;
}
@media screen and (max-width: 768px) {
  .demo .contact-list li:nth-child(3) figure {
    width: 45.5px;
  }
}
.demo .contact-list li figure {
  min-height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 14px;
}
@media screen and (max-width: 768px) {
  .demo .contact-list li figure {
    min-height: 45px;
    margin-bottom: 15px;
  }
}
.demo .contact-list li p {
  text-align: center;
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0.025em;
  font-weight: 400;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .demo .contact-list li p {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.demo .contact-list.--type2 li {
  width: 40.88%;
}
.demo .contact-list.--type2 li + li {
  margin-left: 4%;
}
@media screen and (max-width: 1060px) {
  .demo .contact-list.--type2 li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
@media screen and (max-width: 1060px) {
  .demo .contact-list.--type2 li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .demo .contact-list.--type2 li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.demo .contact-button {
  margin-top: auto;
}
@media screen and (max-width: 768px) {
  .demo .contact-button {
    height: auto;
  }
}
.demo .contact-button a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #3c7be3;
  color: #fff;
  width: 276px;
  min-height: 50px;
  font-size: 14px;
  font-weight: 500;
  padding: 18px 30px;
  border-radius: 25px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .demo .contact-button a {
    width: 190px;
    min-height: 31px;
    padding: 8px 15px 8px;
    border-radius: 31px;
  }
}
.demo .contact-button a::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: 1px;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .demo .contact-button a::after {
    right: 10px;
    border-width: 4px 0 4px 5px;
  }
}
@media (hover: hover) {
  .demo .contact-button a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .demo .contact-button a:hover {
    opacity: 0.7;
  }
}
.demo .contact-button a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1em;
  letter-spacing: 0em;
  display: inline-block;
  padding-bottom: 1px;
}
@media screen and (max-width: 768px) {
  .demo .contact-button a span {
    font-size: 1.1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}

.remodal-wrapper {
  max-height: 100vh;
}

.remodal {
  max-width: none;
}
.remodal.modal {
  background: none;
  margin: auto;
  padding: 0;
  max-width: 860px;
}
.remodal .modal-block {
  height: 100%;
  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;
  position: relative;
}
.remodal .remodal-cancel.modal-close {
  background: none;
  padding: 0;
  width: auto;
  height: auto;
  min-width: auto;
  position: absolute;
  top: -50px;
  right: -8px;
  width: 40px;
  height: 40px;
}
@media screen and (max-width: 768px) {
  .remodal .remodal-cancel.modal-close {
    top: -42px;
    right: -8px;
  }
}
.remodal .remodal-cancel.modal-close::before, .remodal .remodal-cancel.modal-close::after {
  content: "";
  width: 30px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform-origin: 0% 50%;
          transform-origin: 0% 50%;
  -webkit-transform: rotate(45deg) translate(-50%, -50%);
          transform: rotate(45deg) translate(-50%, -50%);
}
.remodal .remodal-cancel.modal-close::after {
  -webkit-transform: rotate(-45deg) translate(-50%, -50%);
          transform: rotate(-45deg) translate(-50%, -50%);
}
.remodal .modal-frame {
  width: 100%;
  aspect-ratio: 8/5;
  position: relative;
}
.remodal .modal-frame iframe {
  width: 100%;
  height: 100%;
}

.page-entry {
  padding-bottom: 0;
}
.page-entry .--module_heroContent {
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .page-entry .--module_heroContent {
    padding: 26px 15px 33px;
  }
}
.page-entry .--module_sectionContent {
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_sectionContent {
    padding: 0;
  }
}
.page-entry .--module_text01 {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_text01 {
    font-size: 12px;
  }
}
.page-entry .--module_text02 {
  font-size: 20px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_text02 {
    font-size: 14px;
  }
}
.page-entry .--module_tag01 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
}
.page-entry .--module_tag01 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_tag01 {
    font-size: 10px;
  }
}
.page-entry .--module_tag02 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.03em;
}
.page-entry .--module_tag02 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_tag02 {
    font-size: 10px;
  }
}
.page-entry .--module_lead01 {
  font-size: 18px;
  line-height: 1.89;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_lead01 {
    font-size: 13px;
    line-height: 1.846;
  }
}
.page-entry .--module_head01 {
  font-size: 36px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_head01 {
    font-size: 20px;
  }
}
.page-entry .--module_head01.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.page-entry .--module_head02 {
  font-size: 28px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_head02 {
    font-size: 16px;
  }
}
.page-entry .--module_head02.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.page-entry .--module_head03 {
  font-size: 20px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_head03 {
    font-size: 14px;
  }
}
.page-entry .--module_head04 {
  display: inline-block;
  font-size: 18px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
  color: #6bcbd8;
  border-bottom: 2px solid #6bcbd8;
}
.page-entry .--module_head04 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_head04 {
    font-size: 10px;
  }
}
.page-entry .--module_head05 {
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
.page-entry .--module_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;
  background-color: #000;
  color: #fff;
  min-width: 300px;
  max-width: 320px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
}
.page-entry .--module_btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.page-entry .--module_headingBg {
  color: #fff;
  text-align: center;
  height: 184px;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #4b4346;
  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;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_headingBg {
    height: 127px;
  }
}
.page-entry .--module_headingBg .--module_head01 {
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .page-entry .--module_headingBg .--module_head01 {
    margin-top: 4px;
  }
}
.page-entry h2.head-ja.--commonMt {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .page-entry h2.head-ja.--commonMt {
    margin-top: 16px;
  }
}
.page-entry section.hero .hero-content {
  padding-top: 80px;
  height: 620px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-top: 40px;
    padding-bottom: 160px;
    height: auto;
    position: relative;
  }
}
.page-entry section.hero .hero-content .textArea {
  text-align: center;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .textArea {
    margin: 0;
  }
}
.page-entry section.hero .hero-content .textArea .hero-content__heading span.head-ja {
  font-size: 20px;
  font-weight: bold;
  border-bottom: 2px solid #000;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .textArea .hero-content__heading span.head-ja {
    font-size: 16px;
    font-weight: 500;
  }
}
.page-entry section.hero .hero-content .textArea .hero-content__heading span.head-en {
  display: block;
  font-size: 56px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.17;
  color: #4b4346;
  margin-top: 30px;
}
.page-entry section.hero .hero-content .textArea .hero-content__heading span.head-en else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .textArea .hero-content__heading span.head-en {
    font-size: 30px;
    margin-top: 16px;
  }
}
.page-entry section.hero .hero-content .textArea .hero-content__text {
  margin-top: 38px;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .textArea .hero-content__text {
    margin-top: 16px;
  }
}
.page-entry section.hero .hero-content .textArea .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;
  background-color: #c12c1f;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  margin-top: 48px;
}
.page-entry section.hero .hero-content .textArea .btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .textArea .btn {
    margin: 0;
    position: absolute;
    bottom: 40px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.page-entry section.hero .hero-content .imageArea {
  margin-right: -100px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .imageArea {
    margin: 60px auto 0;
    text-align: center;
    width: calc(100% - 80px);
  }
}
.page-entry section.hero .hero-content .imageArea .box {
  display: block;
  width: 526px;
  height: 436px;
  background-color: #f7f7f7;
  opacity: 0.8;
  position: absolute;
  z-index: 0;
  top: -80px;
  left: 180px;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .imageArea .box {
    width: calc(100% - 40px);
    height: calc(100% - 16px);
    top: -27.5px;
    left: 70px;
  }
}
.page-entry section.hero .hero-content .imageArea img {
  position: relative;
  z-index: 1;
  -webkit-filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
          filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  will-change: filter;
  -o-object-fit: cover;
     object-fit: cover;
  width: auto;
  height: 460px;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .imageArea img {
    width: 100%;
    height: auto;
  }
}
.page-entry section.hero .hero-content .imageArea::before {
  content: "";
  display: block;
  width: 106px;
  height: 104px;
  border: 10px solid #6bcbd8;
  position: absolute;
  top: -45px;
  left: -48px;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .imageArea::before {
    width: 32px;
    height: 32px;
    border: 5px solid #6bcbd8;
    top: -16.5px;
    left: -17px;
  }
}
.page-entry section.hero .hero-content .imageArea::after {
  content: "";
  display: block;
  width: 380px;
  height: 216px;
  background-color: #6bcbd8;
  position: absolute;
  bottom: -30px;
  left: 114px;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .page-entry section.hero .hero-content .imageArea::after {
    width: calc(100% - 80px);
    height: 72px;
    bottom: -37px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.page-entry section.problem {
  overflow-y: clip;
  position: relative;
  margin-top: 0;
}
.page-entry section.problem::after {
  content: "";
  display: block;
  background-image: url(../../img/entry/round-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 1004px;
  height: 498px;
  position: absolute;
  top: 0;
  right: calc(50% - 63px);
}
@media screen and (max-width: 768px) {
  .page-entry section.problem::after {
    background-image: url(../../img/entry/round-img--sp.png);
    width: 100%;
    height: 430px;
    left: -16px;
    right: auto;
  }
}
.page-entry section.problem .problem-content {
  padding-top: 100px;
  padding-bottom: 120px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content {
    padding-top: 48px;
    padding-bottom: 60px;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__heading {
    padding: 0 15px;
  }
}
.page-entry section.problem .problem-content .problem-content__inner {
  margin: 80px auto 0;
  position: relative;
}
@media screen and (min-width: 1050px) {
  .page-entry section.problem .problem-content .problem-content__inner {
    padding-top: 170px;
  }
}
@media screen and (max-width: 1049px) {
  .page-entry section.problem .problem-content .problem-content__inner {
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner {
    margin: 30px auto 0;
    width: 100%;
  }
}
.page-entry section.problem .problem-content .problem-content__inner .illust {
  width: 172px;
  height: auto;
  margin: auto;
}
@media screen and (max-width: 1049px) {
  .page-entry section.problem .problem-content .problem-content__inner .illust {
    margin: 40px auto 0;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .illust {
    margin: -9px auto 0;
    width: 116px;
  }
}
@media screen and (max-width: 1049px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon + .balloon {
    margin-top: 40px;
  }
}
@media screen and (max-width: 1049px) and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon + .balloon {
    margin-top: 8px;
  }
}
.page-entry section.problem .problem-content .problem-content__inner .balloon {
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
.page-entry section.problem .problem-content .problem-content__inner .balloon .balloon-text {
  text-align: center;
  padding-top: 24px;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon .balloon-text {
    padding-top: 16px;
  }
}
.page-entry section.problem .problem-content .problem-content__inner .balloon.--ver01 {
  background-image: url(../../img/entry/balloon-ver01.png);
  width: 458px;
  height: 143px;
}
@media screen and (min-width: 1050px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver01 {
    position: absolute;
    left: 50%;
    top: 0;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver01 {
    background-image: url(../../img/entry/balloon-ver01--sp.svg);
    width: 260px;
    height: 127px;
  }
}
.page-entry section.problem .problem-content .problem-content__inner .balloon.--ver02 {
  background-image: url(../../img/entry/balloon-ver02.png);
  width: 395px;
  height: 141px;
}
@media screen and (min-width: 1050px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver02 {
    position: absolute;
    right: 0;
    top: 140px;
  }
}
@media screen and (max-width: 1049px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver02 {
    margin-left: auto;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver02 {
    background-image: url(../../img/entry/balloon-ver02--sp.svg);
    width: 235px;
    height: 127px;
    margin-right: -5px;
  }
}
.page-entry section.problem .problem-content .problem-content__inner .balloon.--ver03 {
  background-image: url(../../img/entry/balloon-ver03.svg);
  width: 395px;
  height: 141px;
}
@media screen and (min-width: 1050px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver03 {
    position: absolute;
    left: 0;
    top: 164px;
  }
}
@media screen and (max-width: 1049px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver03 {
    margin-right: auto;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver03 {
    background-image: url(../../img/entry/balloon-ver03--sp.svg);
    width: 247px;
    height: 127px;
    margin-right: 0;
  }
  .page-entry section.problem .problem-content .problem-content__inner .balloon.--ver03 .balloon-text {
    padding-top: 24px;
  }
}
.page-entry section.problem .problem-content .problem-content__intro {
  text-align: center;
  margin-top: 64px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__intro {
    margin-top: 40px;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__intro .intro-text {
    line-height: 2.5;
  }
}
.page-entry section.problem .problem-content .problem-content__intro .arrow {
  width: 47px;
  height: auto;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__intro .arrow {
    width: 33px;
    margin-top: 24px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene {
  margin-top: 54px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene {
    margin-top: 32px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene + .scene {
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene + .scene {
    margin-top: 16px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene {
  background-color: #fff;
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.1));
          filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.1));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  will-change: filter;
  padding: 40px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene {
    padding: 20px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 24px;
  border-bottom: 2px solid #cccccc;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading {
    -webkit-box-align: unset;
        -ms-flex-align: unset;
            align-items: unset;
    padding-bottom: 12px;
    border-bottom: 1px solid #cccccc;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num {
  color: #6bcbd8;
  font-size: 14px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  line-height: 1;
  position: relative;
  margin-right: 32px;
  padding-right: 32px;
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num {
    font-size: 10px;
    margin-right: 20px;
    padding-right: 29px;
    padding-top: 2px;
    padding-bottom: 2px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num::after {
  content: "";
  display: block;
  width: 2px;
  height: 100%;
  background-color: #cccccc;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num::after {
    width: 1px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num .num-text {
  display: inline-block;
  font-size: 60px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin-left: -3px;
  margin-top: 4px;
  letter-spacing: -0.02em;
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num .num-text else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-heading .num .num-text {
    margin-top: 2px;
    font-size: 35px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 32px;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner {
    margin-top: 24px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: center;
  width: 200px;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl {
    width: auto;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust {
    margin: auto;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene01-illust {
  width: 158px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene01-illust {
    width: 117px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene02-illust {
  width: 152px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene02-illust {
    width: 112px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene03-illust {
  width: 161px;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-illust.--scene03-illust {
    width: 118px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-head {
  margin-top: 24px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .ppl .ppl-head {
    margin-top: 16px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail {
  width: 100%;
  padding-left: 40px;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail {
    padding: 0;
    margin-top: 24px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box + .box {
  margin-top: 16px;
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box {
  padding: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box {
    padding: 20px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box01 {
  background-color: #f7f7f7;
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box01 .box-head {
  text-align: center;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box01 .box-head {
    border-bottom: 1px solid #ccc;
    padding-bottom: 12px;
    margin-bottom: 12px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box01 .box-text {
  border-left: 1px solid #ccc;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box01 .box-text {
    border-left: unset;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box02 {
  border: 2px solid #6bcbd8;
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box02 .box-head {
  color: #6bcbd8;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box02 .box-head {
    text-align: center;
    border-bottom: 1px solid #6bcbd8;
    padding-bottom: 12px;
    margin-bottom: 12px;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box02 .box-text {
  border-left: 1px solid #6bcbd8;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box.--box02 .box-text {
    border-left: unset;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box .box-head {
  width: 29%;
  text-align: center;
  margin-right: 24px;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box .box-head {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box .box-head {
    margin: 0;
  }
}
.page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box .box-text {
  width: 71%;
  padding-left: 30px;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 900px) {
  .page-entry section.problem .problem-content .problem-content__scene .scene .scene-inner .detail .box .box-text {
    width: 100%;
    padding: 0;
  }
}
.page-entry .module-contact {
  background-color: #24b3be;
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 96px 0;
}
@media screen and (max-width: 768px) {
  .page-entry .module-contact {
    padding: 48px 0;
  }
}
.page-entry .module-contact::after {
  content: "";
  display: block;
  background-image: url(../../img/entry/module-contact-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center bottom;
  width: 1900px;
  height: 469px;
  position: absolute;
  bottom: -150px;
  left: 50%;
  -webkit-transform: translateX(-50%) rotate(4deg);
          transform: translateX(-50%) rotate(4deg);
}
@media screen and (max-width: 768px) {
  .page-entry .module-contact::after {
    background-image: url(../../img/entry/module-contact-bg--sp.png);
    width: 888px;
    height: 476px;
    bottom: -75px;
  }
}
.page-entry .module-contact .module-contact__text {
  font-family: "Noto Sans JP", "Original Yu Gothic", "Yu Gothic", YuGothic, "Hiragino Sans", sans-serif;
  color: #fff;
  text-align: center;
}
.page-entry .module-contact .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;
  background-color: #fff;
  color: #6bcbd8;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  margin-top: 64px;
}
.page-entry .module-contact .btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .page-entry .module-contact .btn {
    margin-top: 32px;
  }
}
.page-entry section.about {
  overflow-y: clip;
  position: relative;
  padding-top: 96px;
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  .page-entry section.about {
    padding-top: 48px;
  }
}
.page-entry section.about::after {
  content: "";
  display: block;
  background-image: url(../../img/entry/round-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 1004px;
  height: 498px;
  position: absolute;
  top: 0;
  right: calc(50% - 63px);
}
@media screen and (max-width: 768px) {
  .page-entry section.about::after {
    background-image: url(../../img/entry/round-img--sp.png);
    width: 100%;
    height: 430px;
    left: -16px;
    right: auto;
  }
}
.page-entry section.about::before {
  content: "";
  display: block;
  background-image: url(../../img/entry/about-image02.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 980px;
  height: 681px;
  position: absolute;
  top: 0;
  left: calc(50% - 130px);
}
@media screen and (max-width: 768px) {
  .page-entry section.about::before {
    display: none;
  }
}
.page-entry section.about .about-content {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__heading {
    padding: 0 15px;
  }
}
.page-entry section.about .about-content .about-content__textArea {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__textArea {
    padding: 0 15px;
    margin-top: 32px;
  }
}
.page-entry section.about .about-content .about-content__textArea .text + .text {
  margin-top: 16px;
}
.page-entry section.about .about-content .about-content__textArea .text {
  font-weight: bold;
  line-height: 2;
}
.page-entry section.about .about-content .about-content__textArea .text .note {
  font-weight: bold;
  font-size: 12px;
  margin-right: 4px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__textArea .text .note {
    font-size: 10px;
  }
}
.page-entry section.about .about-content .about-content__textArea .text.--onlyPC {
  display: block;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__textArea .text.--onlyPC {
    display: none;
  }
}
.page-entry section.about .about-content .about-content__textArea .text.--onlySP {
  display: none;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__textArea .text.--onlySP {
    display: block;
  }
}
.page-entry section.about .about-content .about-content__textArea .text .--marker {
  display: inline;
  background-color: #6bcbd8;
  color: #fff;
  font-weight: bold;
  padding: 0 4px;
  margin: 0 4px;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
}
.page-entry section.about .about-content .about-content__textArea .text .--marker.--markerLeft {
  padding-left: 12px;
}
.page-entry section.about .about-content .about-content__textArea .text .--marker.--markerRight {
  padding-right: 12px;
}
.page-entry section.about .about-content .about-content__textArea .image {
  display: none;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__textArea .image {
    display: block;
    margin-top: 20px;
    width: 100vw;
  }
  .page-entry section.about .about-content .about-content__textArea .image img {
    width: 100%;
    height: auto;
  }
}
.page-entry section.about .about-content .about-content__inner {
  margin-top: 96px;
  border: 2px solid #6bcbd8;
  padding: 48px 60px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner {
    margin: 0;
    padding: 20px 15px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-head {
  text-align: center;
  border-bottom: 1px solid #6bcbd8;
  padding-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner .inner-head {
    padding-bottom: 16px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-image {
  margin-top: 48px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner .inner-image {
    margin-top: 24px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-comment {
  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: 0 35px;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner .inner-comment {
    margin-top: 32px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__illust {
  width: auto;
  height: 118px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__illust {
    height: 68px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__text {
  background-color: #ebf6fa;
  border-radius: 6px;
  padding: 30px;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__text {
    padding: 16px 12px;
    border-radius: 3px;
  }
}
.page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__text::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 16px 6px 0;
  border-color: transparent #ebf6fa transparent transparent;
  position: absolute;
  top: 50%;
  left: -12px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.page-entry section.about .about-content .about-content__inner .inner-comment .inner-comment__text .color {
  color: #6bcbd8;
  font-weight: bold;
}
.page-entry section.about .about-content .about-note {
  font-size: 12px;
  letter-spacing: 0.08em;
  line-height: 1.8;
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .page-entry section.about .about-content .about-note {
    font-size: 10px;
  }
}
.page-entry section.howto {
  margin-top: 120px;
  padding-top: 96px;
  padding-bottom: 120px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto {
    margin-top: 60px;
    padding-top: 48px;
    padding-bottom: 60px;
  }
}
.page-entry section.howto::after {
  content: "";
  display: block;
  width: 100vw;
  height: 100%;
  background-color: #f7f7f7;
  position: absolute;
  top: 0;
  left: 180px;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto::after {
    left: 15px;
  }
}
.page-entry section.howto .howto-content {
  position: relative;
  z-index: 1;
}
.page-entry section.howto .howto-content .howto-content__heading {
  text-align: center;
}
.page-entry section.howto .howto-content .howto-content__steps {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps {
    margin-top: 32px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step + .step {
  margin-top: 120px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step + .step {
    margin-top: 48px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0 30px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step:nth-child(even) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step:nth-child(even) {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea {
  margin-top: 48px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-textArea {
    margin: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num {
  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;
  background-image: url(../../img/entry/howto-step-bg.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 112px;
  height: 109px;
  padding-bottom: 4px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num {
    width: 70.5px;
    height: 69px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span {
  display: inline-block;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #fff;
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span else {
  font-weight: 500;
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span.en {
  font-size: 14px;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span.en {
    font-size: 10px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span.num {
  font-size: 22px;
  letter-spacing: -0.01em;
  margin-top: 4px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-num span.num {
    font-size: 18px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-text {
  margin-left: 60px;
  margin-top: -32px;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-text {
    margin-top: 0;
    margin-left: 20px;
  }
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-textArea .step-text .--marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(75%, transparent), color-stop(75%, #cdeaee));
  background: linear-gradient(transparent 75%, #cdeaee 75%);
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-movieArea {
  max-width: 610px;
  width: 58%;
}
.page-entry section.howto .howto-content .howto-content__steps .step .step-movieArea video {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .page-entry section.howto .howto-content .howto-content__steps .step .step-movieArea {
    max-width: 100%;
    width: 100%;
    margin-top: 16px;
  }
}
.page-entry section.other .other-content {
  margin-top: 96px;
}
@media screen and (max-width: 768px) {
  .page-entry section.other .other-content {
    margin-top: 68px;
  }
}
.page-entry section.other .other-content .other-content__heading {
  text-align: center;
}
.page-entry section.other .other-content .other-content__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 80px;
  gap: 0 90px;
}
.page-entry section.other .other-content .other-content__inner video {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .page-entry section.other .other-content .other-content__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 32px;
    gap: 16px 0;
  }
}
.page-entry section.other .other-content .other-content__inner .inner-item {
  width: 100%;
}
.page-entry section.other .other-content .other-content__inner .inner-item .inner-item__text {
  text-align: center;
  margin-top: 1em;
}
.page-entry section.otherProb {
  margin-top: 120px;
  padding-top: 90px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb {
    margin-top: 60px;
    padding-top: 48px;
  }
}
.page-entry section.otherProb::after {
  content: "";
  display: block;
  width: 100vw;
  height: calc(100% - 100px);
  background-color: #f7f7f7;
  position: absolute;
  top: 0;
  right: 180px;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb::after {
    right: 15px;
    height: calc(100% - 110px);
  }
}
.page-entry section.otherProb .otherProb-content {
  position: relative;
  z-index: 1;
}
.page-entry section.otherProb .otherProb-content .otherProb-content__heading {
  text-align: center;
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner {
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.1));
          filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.1));
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  will-change: filter;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 50px 60px;
  margin-top: 80px;
  gap: 0 120px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb .otherProb-content .otherProb-content__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 32px 15px;
    gap: 65px 0;
    margin-top: 30px;
  }
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner::after {
  content: "";
  display: block;
  width: 1px;
  height: calc(100% - 100px);
  background-color: #e5e5e5;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb .otherProb-content .otherProb-content__inner::after {
    width: calc(100% - 30px);
    height: 1px;
  }
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item {
  text-align: center;
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__num {
  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;
  width: 67px;
  height: 67px;
  border-radius: 50%;
  font-size: 20px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  background-color: #6bcbd8;
  color: #fff;
  margin: auto;
  line-height: 1;
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__num else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__num {
    width: 50px;
    height: 50px;
    font-size: 16px;
  }
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__text {
  line-height: 1.5;
  font-weight: bold;
  margin-top: 1em;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__text {
    margin-top: 20px;
  }
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__text .color {
  color: #6bcbd8;
  font-weight: bold;
}
.page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__illust {
  margin-top: 48px;
  width: 406px;
}
@media screen and (max-width: 768px) {
  .page-entry section.otherProb .otherProb-content .otherProb-content__inner .inner-item .inner-item__illust {
    width: 100%;
    margin-top: 24px;
  }
}
.page-entry section.price {
  padding: 90px 0 120px;
}
@media screen and (max-width: 768px) {
  .page-entry section.price {
    padding: 60px 0;
  }
}
.page-entry section.price .price-content {
  position: relative;
  z-index: 1;
}
.page-entry section.price .price-content .price-content__heading {
  text-align: center;
}
.page-entry section.price .price-content .price-content__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 80px;
}
@media screen and (max-width: 900px) {
  .page-entry section.price .price-content .price-content__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner {
    margin-top: 32px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box01 {
  width: 43.4%;
  background-color: #ebf6fa;
  padding: 48px 56px;
}
@media screen and (max-width: 900px) {
  .page-entry section.price .price-content .price-content__inner .box.--box01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
    text-align: center;
    padding: 20px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box01 .box-lead {
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box01 .box-lead {
    font-size: 12px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box01 .box-head {
  color: #4b4346;
  line-height: 1.2;
  display: inline-block;
  margin-top: 16px;
}
@media screen and (max-width: 900px) {
  .page-entry section.price .price-content .price-content__inner .box.--box01 .box-head {
    margin-top: 0.5em;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 {
  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;
  width: 56.6%;
  background-color: #fff;
  border-top: 1px solid #e5e5e5;
  border-right: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
}
@media screen and (max-width: 900px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 {
    width: 100%;
    border-top: unset;
    border-left: 1px solid #e5e5e5;
    border-right: 1px solid #e5e5e5;
    border-bottom: 1px solid #e5e5e5;
    padding: 48px;
  }
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 {
    padding: 32px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price {
  text-align: center;
  margin-top: 18px;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 .box-price {
    margin-top: 0;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span {
  display: inline-block;
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-01 {
  font-size: 28px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-01 {
    font-size: 16px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-02 {
  font-size: 58px;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: #6bcbd8;
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-02 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-02 {
    font-size: 30px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-03 {
  font-size: 24px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 .box-price span.split-03 {
    font-size: 14px;
  }
}
.page-entry section.price .price-content .price-content__inner .box.--box02 .box-note {
  display: block;
  text-align: right;
  font-size: 12px;
  letter-spacing: 0.08em;
  margin-top: 2em;
  margin-right: 15%;
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .price-content__inner .box.--box02 .box-note {
    font-size: 10px;
    margin-right: 10%;
  }
}
.page-entry section.price .price-content .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;
  background-color: #6bcbd8;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  margin-top: 64px;
}
.page-entry section.price .price-content .btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .page-entry section.price .price-content .btn {
    margin-top: 32px;
  }
}

.mb64 {
  padding-bottom: 0;
}
.mb64 .--module_heroContent {
  margin: 0 calc(50% - 50vw);
  padding: 0 calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .mb64 .--module_heroContent {
    padding: 26px 15px 33px;
  }
}
.mb64 .--module_sectionContent {
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_sectionContent {
    padding: 0;
  }
}
.mb64 .--module_text01 {
  font-size: 16px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_text01 {
    font-size: 12px;
  }
}
.mb64 .--module_text02 {
  font-size: 20px;
  line-height: 1.875;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_text02 {
    font-size: 14px;
  }
}
.mb64 .--module_tag01 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.01em;
}
.mb64 .--module_tag01 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_tag01 {
    font-size: 10px;
  }
}
.mb64 .--module_tag02 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.03em;
}
.mb64 .--module_tag02 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_tag02 {
    font-size: 10px;
  }
}
.mb64 .--module_lead01 {
  font-size: 18px;
  line-height: 1.89;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_lead01 {
    font-size: 13px;
    line-height: 1.846;
  }
}
.mb64 .--module_head01 {
  font-size: 36px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_head01 {
    font-size: 20px;
  }
}
.mb64 .--module_head01.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.mb64 .--module_head02 {
  font-size: 28px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_head02 {
    font-size: 16px;
  }
}
.mb64 .--module_head02.color {
  color: #6bcbd8;
  border-bottom: 4px solid #6bcbd8;
  font-weight: bold;
  padding: 0 4px;
}
.mb64 .--module_head03 {
  font-size: 20px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_head03 {
    font-size: 14px;
  }
}
.mb64 .--module_head04 {
  display: inline-block;
  font-size: 18px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 600;
  color: #6bcbd8;
  border-bottom: 2px solid #6bcbd8;
}
.mb64 .--module_head04 else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_head04 {
    font-size: 10px;
  }
}
.mb64 .--module_head05 {
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-weight: bold;
}
.mb64 .--module_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;
  background-color: #000;
  color: #fff;
  min-width: 300px;
  max-width: 320px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
}
.mb64 .--module_btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.mb64 .--module_headingBg {
  color: #fff;
  text-align: center;
  height: 184px;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #4b4346;
  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;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_headingBg {
    height: 127px;
  }
}
.mb64 .--module_headingBg .--module_head01 {
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .mb64 .--module_headingBg .--module_head01 {
    margin-top: 4px;
  }
}
.mb64 section.hero {
  width: 100vw;
  background-image: url(../../img/mb64/hero-bg.jpg);
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  margin: 0 calc(50% - 50vw);
  margin-top: 78px;
}
@media screen and (max-width: 1199px) {
  .mb64 section.hero {
    margin-top: 56px;
  }
}
@media screen and (max-width: 999px) {
  .mb64 section.hero {
    margin-top: 0;
  }
}
@media screen and (max-width: 768px) {
  .mb64 section.hero {
    background-image: url(../../img/mb64/hero-bg--sp.jpg);
    background-position: bottom center;
  }
}
.mb64 section.hero .hero-content {
  padding: 0 20px;
  width: 100%;
  max-width: 1090px;
  margin: 0 auto;
  height: 550px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 33px 15px 30px;
    height: 480px;
    position: relative;
  }
}
.mb64 section.hero .hero-content .textArea {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea {
    margin: 0 auto;
    height: 100%;
  }
}
.mb64 section.hero .hero-content .textArea .hero-content__lead {
  max-width: 450px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-content__lead {
    max-width: 185px;
  }
}
.mb64 section.hero .hero-content .textArea .hero-content__lead span {
  color: #fff;
  font-size: 25px;
  font-weight: bold;
  line-height: 1.32;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  display: inline-block;
  position: relative;
  padding-bottom: 6px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-content__lead span {
    font-size: 15px;
    line-height: 1.9666666667;
    letter-spacing: 0.03em;
    padding-bottom: 0;
  }
}
.mb64 section.hero .hero-content .textArea .hero-content__lead span + span {
  margin-top: 12px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-content__lead span + span {
    margin-top: 1px;
  }
}
.mb64 section.hero .hero-content .textArea .hero-content__lead span::before {
  content: "";
  width: 100%;
  height: 2px;
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
}
.mb64 section.hero .hero-content .textArea .hero-content__head {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-content__head {
    margin-top: 12px;
  }
}
.mb64 section.hero .hero-content .textArea .hero-content__tag {
  margin-top: 13px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-content__tag {
    width: 147px;
    margin: 11px auto 0;
  }
}
.mb64 section.hero .hero-content .textArea .btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 56px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .btn-wrap {
    margin-top: 28px;
    -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;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.mb64 section.hero .hero-content .textArea .hero-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;
  background-color: #3c7be3;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  min-width: 235px;
  min-height: 60px;
  border-radius: 30px;
}
.mb64 section.hero .hero-content .textArea .hero-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-btn {
    min-width: 240px;
    min-height: 44px;
    height: 44px;
    border-radius: 22px;
  }
}
.mb64 section.hero .hero-content .textArea .hero-btn.--red {
  background-color: #c12c1f;
}
.mb64 section.hero .hero-content .textArea .hero-btn + .hero-btn {
  margin-left: 24px;
}
@media screen and (max-width: 768px) {
  .mb64 section.hero .hero-content .textArea .hero-btn + .hero-btn {
    margin-top: 18px;
    margin-left: auto;
  }
}
@media (hover: hover) {
  .mb64 section.hero .hero-content .textArea .hero-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 section.hero .hero-content .textArea .hero-btn:hover {
    opacity: 0.7;
  }
}
.mb64 section.about {
  padding-top: 100px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .mb64 section.about {
    padding-top: 37px;
    padding-bottom: 50px;
  }
}
.mb64 section.about .content {
  max-width: 1150px;
}
.mb64 section.about .problem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem {
    padding-left: 7px;
  }
}
.mb64 section.about .problem .problem-head .head {
  margin-top: 14px;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem .problem-head .head {
    margin-top: 6px;
  }
}
.mb64 section.about .problem .problem-head .tag {
  color: #3c7be3;
}
.mb64 section.about .problem .problem-list {
  max-width: 480px;
  margin-top: 42px;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem .problem-list {
    max-width: 100%;
    width: 78.125vw;
    margin-top: 21px;
  }
}
.mb64 section.about .problem .problem-list__item {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.625;
  letter-spacing: 0;
  padding-left: 46px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem .problem-list__item {
    font-size: 12px;
    line-height: 1.875;
    padding-left: 27px;
  }
}
.mb64 section.about .problem .problem-list__item + .problem-list__item {
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem .problem-list__item + .problem-list__item {
    margin-top: 10px;
  }
}
.mb64 section.about .problem .problem-list__item::before {
  content: "";
  width: 28px;
  height: 28px;
  background-image: url("../../img/mb64/icon-check.svg");
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .problem .problem-list__item::before {
    width: 19px;
    height: 19px;
    top: 3px;
  }
}
.mb64 section.about .problem .problem-list__item span {
  font-weight: bold;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(70%, #b1caf4));
  background: linear-gradient(transparent 70%, #b1caf4 70%);
}
.mb64 section.about .icon-arrow {
  width: 47px;
  margin: 56px auto 0;
  display: block;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .icon-arrow {
    width: 33px;
    margin-top: 21px;
  }
}
.mb64 section.about .solution {
  margin-top: 56px;
  padding: 58px 56px 64px;
  background-color: #ebf2fc;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .solution {
    margin-top: 25px;
    padding: 26px 15px 30px;
  }
}
.mb64 section.about .solution .solution-head {
  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;
}
.mb64 section.about .solution .solution-head .tag {
  color: #3c7be3;
}
.mb64 section.about .solution .solution-head .head {
  text-align: center;
  margin-top: 14px;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .solution .solution-head .head {
    margin-top: 7px;
  }
}
.mb64 section.about .solution .solution-head .head span {
  font-weight: bold;
  color: #3c7be3;
  position: relative;
  z-index: 0;
}
.mb64 section.about .solution .solution-head .head span::before {
  content: "";
  width: 100%;
  height: 10px;
  background-color: #b1caf4;
  position: absolute;
  bottom: 2px;
  left: 0;
  z-index: -10;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .solution .solution-head .head span::before {
    height: 6px;
  }
}
.mb64 section.about .solution .solution-body {
  margin-top: 56px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .solution .solution-body {
    margin-top: 21px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
.mb64 section.about .solution .solution-body .solution-text span {
  color: #3c7be3;
  font-weight: bold;
}
.mb64 section.about .solution .solution-body .solution-img {
  width: 47.9744136461%;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.about .solution .solution-body .solution-img {
    width: 81.09375vw;
    margin-top: 28px;
  }
}
.mb64 section.reason {
  position: relative;
  z-index: 0;
}
.mb64 section.reason::before {
  content: "";
  width: 100vw;
  height: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  background-color: #f7f7f7;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -10;
}
.mb64 section.reason .content {
  max-width: 1150px;
  padding-top: 100px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .content {
    padding-top: 40px;
    padding-bottom: 50px;
  }
}
.mb64 section.reason .scene-box {
  padding: 56px;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box {
    padding: 20px;
  }
}
.mb64 section.reason .scene-box + .scene-box {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box + .scene-box {
    margin-top: 16px;
  }
}
.mb64 section.reason .scene-box .scene-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.mb64 section.reason .scene-box .scene-text-wrap {
  width: 53.3049040512%;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-text-wrap {
    width: 100%;
  }
}
.mb64 section.reason .scene-box .scene-head {
  padding-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-head {
    padding-bottom: 20px;
  }
}
.mb64 section.reason .scene-box .scene-head::before {
  content: "";
  width: 30px;
  height: 2px;
  background-color: #ccc;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-head::before {
    width: 23px;
  }
}
.mb64 section.reason .scene-box .head-title {
  margin-left: 18px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .head-title {
    margin-left: 12px;
  }
}
.mb64 section.reason .scene-box .head-img {
  width: 62px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .head-img {
    width: 42px;
  }
}
.mb64 section.reason .scene-box .head-tag .tag {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 400;
  color: #3c7be3;
  font-size: 14px;
}
.mb64 section.reason .scene-box .head-tag .tag else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .head-tag .tag {
    font-size: 10px;
  }
}
.mb64 section.reason .scene-box .head-tag .num {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #3c7be3;
  font-size: 24px;
  margin-left: 5px;
}
.mb64 section.reason .scene-box .head-tag .num else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .head-tag .num {
    margin-left: 3px;
    font-size: 17px;
  }
}
.mb64 section.reason .scene-box .head-name {
  font-size: 18px;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.02em;
  margin-top: 14px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .head-name {
    font-size: 13px;
    line-height: 1.6153846154;
    margin-top: 1px;
  }
}
.mb64 section.reason .scene-box .scene-title {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.02em;
  margin-top: 19px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-title {
    font-size: 16px;
    line-height: 1.5;
    margin-top: 13px;
  }
}
.mb64 section.reason .scene-box .scene-title span {
  color: #fff;
  font-weight: bold;
  display: inline-block;
  padding: 0 6px;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-title span {
    padding: 0 2px;
  }
}
.mb64 section.reason .scene-box .scene-title span::before {
  content: "";
  width: 100%;
  height: 34px;
  background-color: #3c7be3;
  position: absolute;
  top: 5px;
  left: 0;
  z-index: -10;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-title span::before {
    height: 20px;
    top: 3px;
  }
}
.mb64 section.reason .scene-box .scene-thumb {
  width: 44.2430703625%;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-thumb {
    width: 100%;
    margin-top: 24px;
  }
}
.mb64 section.reason .scene-box .scene-thumb img {
  width: 100%;
  border: 1px solid #d6d6d6;
}
.mb64 section.reason .scene-box .scene-video {
  width: 44.2430703625%;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-video {
    width: 100%;
    margin-top: 24px;
  }
}
.mb64 section.reason .scene-box .scene-video video {
  width: 100%;
  height: auto;
}
.mb64 section.reason .scene-box .scene-content {
  margin-top: 48px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content {
    margin-top: 24px;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item {
  padding: 24px 0px 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item {
    padding: 14px 18px 16px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item + .scene-item {
  margin-top: 16px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item + .scene-item {
    margin-top: 12px;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item .text-block {
  border-left: 1px solid #ccc;
  padding: 16px 30px 16px 4.4776119403%;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item .text-block {
    margin-top: 11px;
    padding: 18px 0 0;
    border-top: 1px solid #ccc;
    border-left: none;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item .head {
  font-size: 20px;
  font-weight: bold;
  min-width: 144px;
  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;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item .head {
    font-size: 12px;
    min-width: auto;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item .text {
  letter-spacing: 0;
  line-height: 1.875;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item .text {
    line-height: 1.875;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item .text + .text {
  margin-top: 11px;
}
.mb64 section.reason .scene-box .scene-content .scene-item.--problem {
  background-color: #f7f7f7;
}
.mb64 section.reason .scene-box .scene-content .scene-item.--solution {
  background-color: #ebf2fc;
}
.mb64 section.reason .scene-box .scene-content .scene-item.--solution .head {
  color: #3c7be3;
}
.mb64 section.reason .scene-box .scene-content .scene-item.--solution .text {
  padding-left: 18px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item.--solution .text {
    padding-left: 15px;
  }
}
.mb64 section.reason .scene-box .scene-content .scene-item.--solution .text::before {
  content: "";
  width: 6px;
  height: 6px;
  background-color: #3c7be3;
  position: absolute;
  top: 13px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .scene-box .scene-content .scene-item.--solution .text::before {
    width: 5px;
    height: 5px;
    top: 10px;
  }
}
.mb64 section.reason .reason-lead {
  text-align: center;
  margin-top: 90px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .reason-lead {
    margin-top: 28px;
    line-height: 2;
  }
}
.mb64 section.reason .reason-lead span {
  color: #3c7be3;
  font-weight: bold;
  display: inline-block;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .reason-lead span {
    padding-bottom: 4px;
  }
}
.mb64 section.reason .reason-lead span::before {
  content: "";
  width: 100%;
  height: 4px;
  background-color: #3c7be3;
  position: absolute;
  left: 0;
  bottom: -8px;
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .reason-lead span::before {
    height: 2px;
    bottom: 6px;
  }
}
.mb64 section.reason .reason-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;
  background-color: #3c7be3;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  min-width: 336px;
  min-height: 60px;
  border-radius: 30px;
  margin-top: 64px;
}
.mb64 section.reason .reason-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 section.reason .reason-btn {
    min-width: 290px;
    min-height: 44px;
    height: 44px;
    border-radius: 22px;
    margin-top: 25px;
    font-size: 13px;
    padding-left: 5px;
    padding-right: 5px;
  }
}
@media (hover: hover) {
  .mb64 section.reason .reason-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 section.reason .reason-btn:hover {
    opacity: 0.7;
  }
}
.mb64 section.feature .content {
  max-width: 1150px;
  padding-top: 70px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .content {
    padding-top: 36px;
    padding-bottom: 50px;
  }
}
.mb64 section.feature .lead {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .lead {
    text-align: left;
  }
}
.mb64 section.feature .lead span {
  color: #3c7be3;
  font-weight: bold;
}
.mb64 section.feature .feature-content {
  margin-top: 90px;
  background-color: #f7f7f7;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-content {
    margin-top: 35px;
  }
}
.mb64 section.feature .feature-box {
  padding: 80px 0;
  margin: 0 56px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box {
    padding: 30px 0 28px;
    margin: 0 15px;
  }
}
.mb64 section.feature .feature-box + .feature-box {
  border-top: 1px solid #ccc;
}
.mb64 section.feature .feature-box .feature-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.mb64 section.feature .feature-box .feature-head .tag {
  color: #fff;
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  width: 128px;
  height: 36px;
  padding-top: 1px;
  padding-right: 6px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  background-color: #3c7be3;
  position: relative;
}
.mb64 section.feature .feature-box .feature-head .tag else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-head .tag {
    font-size: 10px;
    width: 91px;
    height: 20px;
    padding-top: 0;
    padding-right: 6px;
  }
}
.mb64 section.feature .feature-box .feature-head .tag::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 0 18px 12px;
  border-color: transparent transparent transparent #3c7be3;
  position: absolute;
  top: 0;
  right: -12px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-head .tag::before {
    border-width: 10px 0 10px 6px;
    right: -6px;
  }
}
.mb64 section.feature .feature-box .feature-head .title {
  margin-left: 30px;
  padding-bottom: 2px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-head .title {
    margin-top: 7px;
    margin-left: 0;
    padding-bottom: 0;
  }
}
.mb64 section.feature .feature-box .feature-text {
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-text {
    margin-top: 17px;
  }
}
.mb64 section.feature .feature-box .feature-list {
  margin-top: 34px;
  padding: 25px 32px;
  background-color: #ebf2fc;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-list {
    margin-top: 15px;
    padding: 15px;
  }
}
.mb64 section.feature .feature-box .feature-list .item {
  font-size: 14px;
  line-height: 1.8571428571;
  padding-left: 18px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-list .item {
    font-size: 12px;
    line-height: 1.875;
  }
}
.mb64 section.feature .feature-box .feature-list .item + .item {
  margin-top: 4px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-list .item + .item {
    margin-top: 5px;
  }
}
.mb64 section.feature .feature-box .feature-list .item::before {
  content: "";
  width: 6px;
  height: 6px;
  background-color: #3c7be3;
  position: absolute;
  top: 13px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-list .item::before {
    width: 5px;
    height: 5px;
    top: 8px;
  }
}
.mb64 section.feature .feature-box .feature-list .item span {
  color: #3c7be3;
  font-weight: bold;
}
.mb64 section.feature .feature-box .feature-img {
  margin-top: 34px;
  padding: 32px;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-box .feature-img {
    margin-top: 15px;
    padding: 15px;
  }
  .mb64 section.feature .feature-box .feature-img video {
    width: 100%;
    height: auto;
  }
}
.mb64 section.feature .feature-lead {
  text-align: center;
  margin-top: 90px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-lead {
    margin-top: 28px;
    line-height: 2;
  }
}
.mb64 section.feature .feature-lead span {
  color: #3c7be3;
  font-weight: bold;
  display: inline-block;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-lead span {
    padding-bottom: 4px;
  }
}
.mb64 section.feature .feature-lead span::before {
  content: "";
  width: 100%;
  height: 4px;
  background-color: #3c7be3;
  position: absolute;
  left: 0;
  bottom: -8px;
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-lead span::before {
    height: 2px;
    bottom: 6px;
  }
}
.mb64 section.feature .feature-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;
  background-color: #3c7be3;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  min-width: 350px;
  min-height: 60px;
  border-radius: 30px;
  margin-top: 64px;
}
.mb64 section.feature .feature-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 section.feature .feature-btn {
    min-width: 290px;
    min-height: 44px;
    height: 44px;
    border-radius: 22px;
    margin-top: 25px;
    font-size: 13px;
    padding-left: 5px;
    padding-right: 5px;
  }
}
@media (hover: hover) {
  .mb64 section.feature .feature-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 section.feature .feature-btn:hover {
    opacity: 0.7;
  }
}
.mb64 section.case .content {
  max-width: 1150px;
  padding-top: 80px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .content {
    padding-top: 36px;
    padding-bottom: 50px;
  }
}
.mb64 section.case .case-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.mb64 section.case .case-lead {
  margin-top: 16px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-lead {
    margin-top: 0;
  }
}
.mb64 section.case .case-lead span {
  color: #3c7be3;
  font-weight: bold;
}
.mb64 section.case .case-img {
  width: 620px;
  position: relative;
  left: 72px;
}
@media screen and (max-width: 1119px) {
  .mb64 section.case .case-img {
    left: 52px;
  }
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-img {
    width: 84.53125vw;
    margin-top: 33px;
    left: 0;
  }
}
.mb64 section.case .case-list {
  margin-top: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list {
    margin-top: 40px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}
.mb64 section.case .case-list .item {
  width: 23.8095238095%;
  -webkit-box-shadow: 0 0 26px rgba(49, 60, 71, 0.3);
          box-shadow: 0 0 26px rgba(49, 60, 71, 0.3);
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item + .item {
    margin-top: 25px;
  }
}
.mb64 section.case .case-list .item-thumb {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-thumb img {
    width: 100%;
  }
}
.mb64 section.case .case-list .text-wrap {
  padding: 0 9.6% 32px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .text-wrap {
    padding: 0 4.6875vw 32px;
  }
}
.mb64 section.case .case-list .item-title {
  font-size: 18px;
  line-height: 1.6666666667;
  font-weight: bold;
  min-height: 60px;
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-title {
    font-size: 16px;
    line-height: 1.4375;
    min-height: auto;
    margin-top: 20px;
    text-align: center;
  }
}
.mb64 section.case .case-list .item-text {
  font-size: 14px;
  line-height: 1.8571428571;
  margin-top: 13px;
  min-height: 202px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-text {
    font-size: 12px;
    line-height: 1.875;
    margin-top: 20px;
    min-height: auto;
  }
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-logo {
    text-align: center;
    height: 30px;
    margin-top: 20px;
  }
  .mb64 section.case .case-list .item-logo img {
    height: 100%;
    width: auto;
  }
}
.mb64 section.case .case-list .item-desc {
  margin-top: 28px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-desc {
    margin-top: 27px;
    width: 100%;
  }
  .mb64 section.case .case-list .item-desc img {
    width: 100%;
  }
}
.mb64 section.case .case-list .item-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.mb64 section.case .case-list .item-link a {
  color: #3c7be3;
  font-size: 15px;
  font-weight: 400;
  letter-spacing: -0.04em;
  text-align: center;
  min-height: 36px;
  margin: 14px auto 0;
  padding: 0 22px 0 4px;
  position: relative;
  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;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-link a {
    font-size: 12px;
    min-height: 31px;
    margin: 10px auto 0;
    padding: 0 22px 0 4px;
  }
}
.mb64 section.case .case-list .item-link a::before {
  content: "";
  width: 100%;
  height: 2px;
  background-color: #3c7be3;
  position: absolute;
  left: 0;
  bottom: 0;
}
.mb64 section.case .case-list .item-link a::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 8px;
  border-color: transparent transparent transparent #007bff;
  position: absolute;
  top: calc(50% + 1px);
  right: 2px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-list .item-link a::after {
    border-width: 4px 0 4px 6px;
  }
}
@media (hover: hover) {
  .mb64 section.case .case-list .item-link a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 section.case .case-list .item-link a:hover {
    opacity: 0.7;
  }
}
.mb64 section.case .case-box {
  margin-top: 80px;
  padding: 64px 56px 80px;
  background-color: #f7f7f7;
  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;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box {
    margin-top: 37px;
    padding: 25px 15px 34px;
  }
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .title {
    text-align: center;
  }
}
.mb64 section.case .case-box .title span {
  color: #3c7be3;
  font-weight: bold;
}
.mb64 section.case .case-box .lead {
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .lead {
    font-size: 13px;
    line-height: 1.8461538462;
    margin-top: 12px;
  }
}
.mb64 section.case .case-box .case-box-wrap {
  background-color: #fff;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .case-box-wrap {
    margin-top: 30px;
  }
}
.mb64 section.case .case-box .case-box-wrap {
  padding: 24px 40px 24px 0;
  background-color: #fff;
  margin-top: 46px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .case-box-wrap {
    padding: 29px 15px 25px;
    margin: 25px 0 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.mb64 section.case .case-box .case-box-wrap .head {
  color: #3c7be3;
  font-size: 20px;
  font-weight: bold;
  min-width: 318px;
  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;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .case-box-wrap .head {
    font-size: 17px;
    min-width: auto;
  }
}
.mb64 section.case .case-box .case-box-wrap .text {
  border-left: 1px solid #ccc;
  padding: 17px 5.8355437666% 17px;
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .case-box-wrap .text {
    margin-top: 32px;
    padding: 10px 0 0;
    border-top: 1px solid #ccc;
    border-left: none;
  }
}
.mb64 section.case .case-box .case-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;
  background-color: #3c7be3;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  min-width: 337px;
  min-height: 60px;
  border-radius: 30px;
  margin-top: 57px;
}
.mb64 section.case .case-box .case-btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 section.case .case-box .case-btn {
    min-width: 260px;
    min-height: 44px;
    height: 44px;
    border-radius: 22px;
    margin-top: 30px;
    font-size: 13px;
    padding-left: 5px;
    padding-right: 5px;
  }
}
@media (hover: hover) {
  .mb64 section.case .case-box .case-btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 section.case .case-box .case-btn:hover {
    opacity: 0.7;
  }
}
.mb64 .contact {
  background: url(../../img/demo/contact_bg.png) center top/cover no-repeat;
  margin: 0 calc(50% - 50vw);
  padding: 60px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .mb64 .contact {
    background: url(../../img/demo/contact_bg_sp.png) center top/cover no-repeat;
    padding: 40px 30px;
  }
}
.mb64 .contact-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 1060px) {
  .mb64 .contact-list {
    -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;
  }
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.mb64 .contact-list li {
  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;
  text-align: center;
  width: 29.0434782609%;
  background-color: #fff;
  padding: 37px 0 49px;
}
@media screen and (max-width: 1060px) {
  .mb64 .contact-list li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.mb64 .contact-list li + li {
  margin-left: 2.7826086957%;
}
@media screen and (max-width: 1060px) {
  .mb64 .contact-list li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
.mb64 .contact-list li:nth-child(1) figure {
  width: 41px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li:nth-child(1) figure {
    width: 31.5px;
  }
}
.mb64 .contact-list li:nth-child(2) figure {
  width: 47px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li:nth-child(2) figure {
    width: 40.5px;
  }
}
.mb64 .contact-list li:nth-child(3) figure {
  width: 54px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li:nth-child(3) figure {
    width: 45.5px;
  }
}
.mb64 .contact-list li figure {
  min-height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 14px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li figure {
    min-height: 45px;
    margin-bottom: 15px;
  }
}
.mb64 .contact-list li p {
  text-align: center;
  font-size: 2rem;
  line-height: 1em;
  letter-spacing: 0.025em;
  font-weight: 400;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list li p {
    font-size: 1.6rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 20px;
  }
}
.mb64 .contact-list.--type2 li {
  width: 40.88%;
}
.mb64 .contact-list.--type2 li + li {
  margin-left: 4%;
}
@media screen and (max-width: 1060px) {
  .mb64 .contact-list.--type2 li + li {
    margin-top: 20px;
    margin-left: 0;
  }
}
@media screen and (max-width: 1060px) {
  .mb64 .contact-list.--type2 li {
    width: 100%;
    max-width: 400px;
    padding: 20px 0 25px;
  }
}
@media screen and (max-width: 768px) {
  .mb64 .contact-list.--type2 li {
    padding: 20px 0 25px;
    width: 100%;
    margin: 0;
  }
}
.mb64 .contact-button {
  margin-top: auto;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-button {
    height: auto;
  }
}
.mb64 .contact-button a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #3c7be3;
  color: #fff;
  width: 276px;
  min-height: 50px;
  font-size: 14px;
  font-weight: 500;
  padding: 18px 30px;
  border-radius: 25px;
  margin: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-button a {
    width: 190px;
    min-height: 31px;
    padding: 8px 15px 8px;
    border-radius: 31px;
  }
}
.mb64 .contact-button a::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: 1px;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .mb64 .contact-button a::after {
    right: 10px;
    border-width: 4px 0 4px 5px;
  }
}
@media (hover: hover) {
  .mb64 .contact-button a {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .mb64 .contact-button a:hover {
    opacity: 0.7;
  }
}
.mb64 .contact-button a span {
  color: #fff;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1em;
  letter-spacing: 0em;
  display: inline-block;
  padding-bottom: 1px;
}
@media screen and (max-width: 768px) {
  .mb64 .contact-button a span {
    font-size: 1.1rem;
    line-height: 1em;
    letter-spacing: 0em;
  }
}

.remodal-wrapper {
  max-height: 100vh;
}

.remodal {
  max-width: none;
}
.remodal.modal {
  background: none;
  margin: auto;
  padding: 0;
  max-width: 860px;
}
.remodal .modal-block {
  height: 100%;
  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;
  position: relative;
}
.remodal .remodal-cancel.modal-close {
  background: none;
  padding: 0;
  width: auto;
  height: auto;
  min-width: auto;
  position: absolute;
  top: -50px;
  right: -8px;
  width: 40px;
  height: 40px;
}
@media screen and (max-width: 768px) {
  .remodal .remodal-cancel.modal-close {
    top: -42px;
    right: -8px;
  }
}
.remodal .remodal-cancel.modal-close::before, .remodal .remodal-cancel.modal-close::after {
  content: "";
  width: 30px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform-origin: 0% 50%;
          transform-origin: 0% 50%;
  -webkit-transform: rotate(45deg) translate(-50%, -50%);
          transform: rotate(45deg) translate(-50%, -50%);
}
.remodal .remodal-cancel.modal-close::after {
  -webkit-transform: rotate(-45deg) translate(-50%, -50%);
          transform: rotate(-45deg) translate(-50%, -50%);
}
.remodal .modal-frame {
  width: 100%;
  aspect-ratio: 8/5;
  position: relative;
}
.remodal .modal-frame iframe {
  width: 100%;
  height: 100%;
}

#onetrust-banner-sdk {
  display: none;
}

.str-renew {
  scroll-behavior: auto;
}
.str-renew.--primary .l-header {
  position: fixed;
}
@media screen and (min-width: 1200px) {
  .str-renew.--primary .l-header {
    height: auto;
  }
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .l-header {
    padding-right: 0;
  }
}
@media screen and (min-width: 1200px) {
  .str-renew.--primary .m-header {
    height: auto;
    padding-top: 11px;
    padding-bottom: 11px;
    background-color: #fff;
  }
}
@media screen and (max-width: 768px) {
  .str-renew.--primary .m-header {
    padding-top: 0;
    padding-bottom: 0;
  }
}
@media screen and (min-width: 1200px) {
  .str-renew.--primary .m-header__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.str-renew.--primary .m-header__headline {
  width: auto;
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-header__headline {
    width: 100%;
  }
}
.str-renew.--primary .m-header__wrapper {
  margin-left: 96px;
  width: 100%;
}
.str-renew.--primary .m-header__wrapper .m-header__button {
  margin-right: 0;
}
@media screen and (min-width: 1200px) {
  .str-renew.--primary .m-nav-global__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.str-renew.--primary .m-nav-global__list .m-nav-global__item a {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4285714286;
  letter-spacing: 0;
}
.str-renew.--primary .m-nav-global__list .m-nav-global__item + .m-nav-global__item {
  margin-left: 25px;
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-nav-global__list .m-nav-global__item + .m-nav-global__item {
    margin-left: 0;
  }
}
@media (hover: hover) {
  .str-renew.--primary .m-nav-global__list .m-nav-global__item {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .str-renew.--primary .m-nav-global__list .m-nav-global__item:hover {
    opacity: 0.7;
  }
}
.str-renew.--primary .m-header__logo {
  padding-bottom: 0;
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-nav-global__button.js-megaMenu__hook::before {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
}
.str-renew.--primary .m-header__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: auto;
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-header__btn {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 16px auto 0;
    max-width: 440px;
  }
}
.str-renew.--primary .m-header__btn .--module_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;
  background-color: #3c7be3;
  color: #fff;
  min-width: 300px;
  max-width: 300px;
  height: 60px;
  font-size: 14px;
  font-weight: 500;
  padding: 0 50px;
  border-radius: 29.5px;
  margin: auto;
  position: relative;
  font-size: 13px;
  font-weight: 400;
  width: auto;
  height: auto;
  min-width: 132px;
  min-height: 42px;
  border-radius: 21px;
  padding: 0;
}
.str-renew.--primary .m-header__btn .--module_btn::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 6px;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  right: 25px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-header__btn .--module_btn {
    min-width: 100%;
    min-height: 44px;
    height: 44px;
    border-radius: 22px;
  }
}
.str-renew.--primary .m-header__btn .--module_btn::after {
  display: none;
}
.str-renew.--primary .m-header__btn .--module_btn.--red {
  background-color: #c12c1f;
}
.str-renew.--primary .m-header__btn .--module_btn + .--module_btn {
  margin-left: 16px;
}
@media screen and (max-width: 1199px) {
  .str-renew.--primary .m-header__btn .--module_btn + .--module_btn {
    margin-top: 18px;
    margin-left: 0;
  }
}
@media (hover: hover) {
  .str-renew.--primary .m-header__btn .--module_btn {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
  }
  .str-renew.--primary .m-header__btn .--module_btn:hover {
    opacity: 0.7;
  }
}
.str-renew.--primary .l-footer {
  height: 52px;
  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;
}
@media screen and (max-width: 768px) {
  .str-renew.--primary .l-footer {
    height: 63px;
    padding: 15px 20px 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.str-renew.--primary .l-footer .copy {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 300;
  color: #000;
  font-size: 12px;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  background: none;
}
.str-renew.--primary .l-footer .copy else {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .str-renew.--primary .l-footer .copy {
    font-size: 11px;
    letter-spacing: 0.03em;
    padding: 0;
  }
}

#reason,
#feature,
#case {
  position: relative;
  top: -79px;
}
@media screen and (max-width: 768px) {
  #reason,
  #feature,
  #case {
    top: -56px;
  }
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title.type01::before {
    left: calc(50% + 110px);
    width: 171px;
    height: 210px;
    background: url(../../img/index/task_ideal_img_02.png) no-repeat center/cover;
  }
}

/* top mv */
.index .mv {
  position: relative;
  margin: 0 calc(50% - 50vw) 0;
  overflow: hidden;
  background-color: #fff;
  background-image: url(../../img/index/mv_bg.png);
  background-size: 1642px auto;
  background-position: calc(50% - 10px) calc(50% - 20px);
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .index .mv {
    background-size: 300% auto;
    background-position: center calc(50% + 70px);
  }
}
.index .mv .mv-inner {
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .index .mv .mv-inner {
    padding: 0 15px;
  }
}
.index .mv .mv-wrap {
  display: flex;
  justify-content: flex-end;
  padding: 70px 0 25px;
  max-width: 1240px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .index .mv .mv-wrap {
    flex-direction: column;
    padding: 30px 0;
    align-items: center;
  }
}
.index .mv .mv-content {
  text-align: center;
  flex: 1;
}
.index .mv .mv-title {
  display: inline-block;
  font-size: 3.8rem;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-title {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-title {
    font-size: 1.9rem;
  }
}
.index .mv .mv-logo {
  margin-top: 20px;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-logo {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-logo {
    width: 100%;
  }
}
.index .mv .mv-logo img {
  display: block;
  width: 100%;
  max-width: 426px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .index .mv .mv-logo img {
    max-width: 290px;
  }
}
.index .mv .mv-subtitle {
  color: #3C7BE3;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 20px;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-subtitle {
    font-size: 1.8rem;
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-subtitle {
    font-size: 1.4rem;
  }
}
.index .mv .mv-share {
  margin-top: 15px;
  display: flex;
  gap: 62px;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-share {
    gap: 30px;
    margin-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-share {
    gap: 15px;
  }
}
.index .mv .mv-share .img-01 {
  height: 80px;
  width: auto;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-share .img-01 {
    height: 60px;
  }
}
.index .mv .mv-share .img-02 {
  height: 117px;
  width: auto;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-share .img-02 {
    height: 97px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-share .img-02 {
    height: 80px;
  }
}
.index .mv .mv-share img {
  height: 100%;
  width: auto;
}
.index .mv .mv-note {
  font-size: 1.0rem;
  line-height: 1.6;
  margin-top: 30px;
  text-align: left;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .index .mv .mv-note {
    margin-top: 10px;
  }
}
.index .mv .mv-img {
  width: 620px;
  position: relative;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-img {
    width: 450px;
    margin-top: 30px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-img {
    width: 320px;
  }
}
.index .mv .mv-img .img-01 {
  position: relative;
  z-index: 2;
}
.index .mv .mv-img .img-02 {
  position: absolute;
  width: 410px;
  top: 7px;
  left: 105px;
  z-index: 1;
}
@media screen and (max-width: 1180px) {
  .index .mv .mv-img .img-02 {
    width: 300px;
    top: 4px;
    left: 75px;
  }
}
@media screen and (max-width: 768px) {
  .index .mv .mv-img .img-02 {
    width: 212px;
    top: 4px;
    left: 53px;
  }
}
.index .mv .mv-img img {
  width: 100%;
}


.index .task-ideal .index-belt-title.type01 {
  position: relative;
  padding: 50px calc(50vw - 40%) 50px calc(50vw - 60%);
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title.type01 {
    padding: 25px calc(50vw - 50%) 25px;
  }
}

.index .task-ideal .index-belt-title.type01::before {
  content: "";
  position: absolute;
  left: calc(50% + 350px);
  bottom: 0;
  width: 314px;
  height: 301px;
  background: url(../../img/index/task_ideal_img_01.png) no-repeat center/cover;
  transform: translateX(-50%);
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .index .task-ideal .index-belt-title.type01::before {
    left: calc(50% + 110px);
    width: 171px;
    height: 210px;
    background: url(../../img/index/task_ideal_img_02.png) no-repeat center/cover;
  }
}

.index .task-ideal .index-belt-title.type01 .index-entitle,
.index .task-ideal .index-belt-title.type01 .index-title {
  position: relative;
  text-align: center;
  z-index: 2;
}
.index .news {
  background-color: #f3f2f2;
  margin: 0 calc(50% - 50vw);
  padding: 80px calc(50vw - 50%);
}
@media screen and (max-width: 768px) {
  .index .news {
    padding: 30px 15px;
  }
}
.index .news h2 {
    text-align: center;
    font-weight: 700;
    font-size: 3.6rem;
    line-height: 1em;
    letter-spacing: -0.01em;
    margin-bottom: 35px;
}
@media screen and (max-width: 768px) {
  .index .news h2 {
    font-size: 2.2rem;
    line-height: 1em;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.news .news-list {
  width: 100%;
  max-width: 1050px;
  margin: 62px auto 0
}
@media screen and (max-width: 768px) {
  .news .news-list {
    margin-top: 40px
  }
}
.news .news-list__item {
  width: 100%;
  position: relative;
  border-top: 1px solid #ebebeb;
  border-bottom: 1px solid #ebebeb
}
.news .news-list__item + .news-list__item {
  border-top: none
}
.news .news-list__item::before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 9px;
  border-color: transparent transparent transparent #3c7be3;
  position: absolute;
  top: 50%;
  right: 26px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}
@media screen and (max-width: 768px) {
  .news .news-list__item::before {
    right: 0;
    border-width: 3.5px 0 3.5px 4px
  }
}
@media (hover: hover) {
  .news .news-list__item {
    -webkit-transition: opacity 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out
  }
  .news .news-list__item:hover {
    opacity: 0.7
  }
}
.news .news-list__item .link {
  width: 100%;
  height: 100%;
  min-height: 100px;
  padding: 10px 40px 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}
@media screen and (max-width: 768px) {
  .news .news-list__item .link {
    padding: 14px 20px 14px 0;
    min-height: 87px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
  }
}
.news .news-list__item .item-date {
  color: #3c7be3;
  font-size: 15px;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  min-width: 6em;
}
@media screen and (max-width: 768px) {
  .news .news-list__item .item-date {
    font-size: 12px
  }
}
.news .news-list__item .item-text {
  font-size: 14px;
  line-height: 2.35714;
  margin-left: 24px;
  padding-left: 28px;
  position: relative
}
@media screen and (max-width: 768px) {
  .news .news-list__item .item-text {
    font-size: 11px;
    line-height: 1.63636;
    margin: 0;
    padding-left: 0
  }
}
.news .news-list__item .item-text::before {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #ebebeb;
  position: absolute;
  top: 0;
  left: 0
}
@media screen and (max-width: 768px) {
  .news .news-list__item .item-text::before {
    display: none;
  }
}


.index .form {
  margin: 0 calc(50% - 50vw);
  padding: 80px 20px;
  background-color: #EBF2FC;
}
@media screen and (max-width: 768px) {
  .index .form {
    padding: 30px 15px;
  }
}
.index .form h2 {
  text-align: center;
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1.6;
  letter-spacing: -0.01em;
  margin-bottom: 75px;
}
@media screen and (max-width: 768px) {
  .index .form h2 {
    font-size: 1.9rem;
    line-height: 2.9rem;
    letter-spacing: 0em;
    margin-bottom: 25px;
  }
}
.index .form .form-box {
  max-width: 793px;
  margin: 0 auto;
}
.index .form .form-box form {
  width: 100%!important;
  margin: 0 auto;
}
/* パーツ */
/* 共通 */
.index .form .form-box .mktoLabel {
  font-weight: bold;
  text-align: right;
  line-height: 1.5;
}
.index .form .form-box .mktoButtonRow {
  text-align: center;
  display: block;
}
.index .form .form-box input,
.index .form .form-box textarea,
.index .form .form-box select {
  border: 1px solid #3C7BE3;
  border-radius: 3px;
}
.index .form .form-box input[type="radio"] {
  position: relative;
  background-color: #fff;
  border-radius: 50%;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0!important;
}
.index .form .form-box input[type="radio"]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: #3C7BE3;
  content: '';
}
.index .form .form-box input[type="radio"] + label {
  color: #000!important;
}
.index .form .form-box select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url(../../img/index/form_icon_arrow.svg);
  background-repeat: no-repeat;
  background-color: #fff;
}
.index .form .form-box input[type="checkbox"] {
  position: relative;
  background-color: #fff;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0!important;
}
.index .form .form-box input[type="checkbox"]:checked:before {
  position: absolute;
  transform: rotate(50deg);
  border-right: 2px solid #3C7BE3;
  border-bottom: 2px solid #3C7BE3;
  content: '';
}
.index .form .form-box .mktoAsterix {
  color: #FF0000;
}
.index .form .form-box #attention {
  color: #3C7BE3;
}
.index .form .form-box #Lblattribute2__c {
  width: 20px!important;
}
.index .form .form-box .mktoButtonWrap {
  margin-left: 0!important;
}
.index .form .form-box .mktoLogicalField label {
  color: #000!important;
}
.index .form .form-box .mktoLogicalField label a {
  text-decoration: underline;
}
.index .form .form-box .mktoButton {
  background: #b40200!important;
  border: none!important;
  font-weight: bold!important;
  border-radius: 100px;
}

/* PC */
@media screen and (min-width: 769px) {
  .index .form .form-box .mktoTextField,
  .index .form .form-box .mktoRadioList,
  .index .form .form-box .mktoEmailField,
  .index .form .form-box .mktoTelField,
  .index .form .form-box textarea {
    width: 350px!important;
  }
  .index .form .form-box input,
  .index .form .form-box textarea,
  .index .form .form-box select {
    padding: 10px 10px 8px 10px;
    font-size: 16px;
  }
  .index .form .form-box input[type="radio"] {
    width: 16px;
    height: 16px;
  }
  .index .form .form-box input[type="radio"]:checked:before {
    width: 10px;
    height: 10px;
  }
  .index .form .form-box input[type="radio"] + label {
    font-size: 16px;
    margin-top: 1px;
    margin-bottom: 5px;
    margin-left: 25px;
  }
  .index .form .form-box select {
    width: 250px!important;
    background-position: calc(100% - 10px) center;
    background-size: 11px auto;
  }
  .index .form .form-box input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin-top: 3px;
  }
  .index .form .form-box input[type="checkbox"]:checked:before {
    top: 1px;
    left: 4px;
    width: 6px;
    height: 9px;
  }
  .index .form .form-box input[type="checkbox"] + label {
    margin-left: 25px;
  }
  .index .form .form-box textarea {
    height: 180px!important;
  }
  .index .form .form-box .mktoHtmlText {
    width: 100%!important;
    padding-left: 20px;
  }
  .index .form .form-box .mktoLabel {
    width: 230px!important;
    font-size: 16px!important;
  }
  .index .form .form-box .mktoFormRow {
    margin-bottom: 10px;
  }
  .index .form .form-box .mktoAsterix {
    font-size: 16px;
  }
  .index .form .form-box #attention {
    font-size: 15px;
    line-height: 1.5;
    margin-left: 220px;
  }
  .index .form .form-box .mktoLogicalField label {
    width: 660px!important;
    font-size: 16px!important;
    line-height: 1.5;
  }
  .index .form .form-box .mktoButton {
    width: 360px!important;
    padding: 23px 0!important;
    transition: opacity 0.2s ease-in-out!important;
    font-size: 16px!important;
  }
  .index .form .form-box .mktoButton:hover {
    opacity: 0.7!important;
  }
}
/* SP */
@media screen and (max-width: 768px) {
  .index .form .form-box .mktoForm input,
  .index .form .form-box .mktoForm textarea,
  .index .form .form-box .mktoForm select {
    padding: 6px!important;
    font-size: 14px;
  }
  .index .form .form-box input[type="radio"] {
    width: 16px;
    height: 16px;
  }
  .index .form .form-box input[type="radio"]:checked:before {
    width: 10px;
    height: 10px;
  }
  .index .form .form-box input[type="radio"] + label {
    font-size: 14px;
    margin-top: 1px;
    margin-bottom: 5px;
    margin-left: 25px;
  }
  .index .form .form-box select {
    width: 250px!important;
    background-position: calc(100% - 10px) center;
    background-size: 11px auto;
  }
  .index .form .form-box input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin-top: 3px;
  }
  .index .form .form-box input[type="checkbox"]:checked:before {
    top: 1px;
    left: 4px;
    width: 6px;
    height: 9px;
  }
  .index .form .form-box input[type="checkbox"] + label {
    margin-left: 25px;
  }
  .index .form .form-box .mktoLabel {
    font-size: 14px!important;
  }
  .index .form .form-box .mktoLogicalField label {
    font-size: 14px!important;
    line-height: 1.5;
  }
  .index .form .form-box #attention {
    font-size: 13px;
  }
  .index .form .form-box .mktoButton {
    width: 280px!important;
    padding: 20px 0!important;
    transition: opacity 0.2s ease-in-out!important;
    font-size: 14px!important;
  }
}
/* SP調整（481-768） */
@media screen and (min-width: 481px) and (max-width: 768px) {
  .index .form .form-box .mktoTextField,
  .index .form .form-box .mktoRadioList,
  .index .form .form-box .mktoEmailField,
  .index .form .form-box .mktoTelField,
  .index .form .form-box textarea {
    width: 250px!important;
  }
  .index .form .form-box textarea {
    height: 180px!important;
  }
  .index .form .form-box .mktoHtmlText {
    width: 100%!important;
  }
  .index .form .form-box .mktoLabel {
    width: 140px!important;
  }
  .index .form .form-box .mktoLogicalField label {
    width: 360px!important;
  }
}
/* SP調整（-495） */
@media screen and (max-width: 495px) {
  .index .form .form-box .mktoLabel {
    margin-right: 10px;
  }
}
/* SP調整（-480） */
@media screen and (max-width: 480px) {
  .index .form .form-box .mktoTextField,
  .index .form .form-box .mktoEmailField,
  .index .form .form-box .mktoTelField,
  .index .form .form-box select {
    height: 35px!important;
  }
  .index .form .form-box .mktoLabel {
    text-align: left;
  }
  .index .form .form-box textarea {
    height: 130px!important;
  }
}

/* hdiバナー */
.quality {
  padding-top: 90px;
}
@media screen and (max-width: 768px){
  .quality {
      padding-top: 30px;
  }
}
.quality .quality-banner {
  display: flex;
  align-items: center;
  gap: 20px 38px;
  max-width: 980px;
  width: 100%;
  padding: 40px;
  border: 1px solid #3C7BE3;
  margin-inline: auto;
}
@media screen and (max-width: 768px){
  .quality .quality-banner {
      flex-direction: column;
      max-width: none;
      padding: 20px 20px 30px;
  }
}
.quality .quality-banner-img {
  width: 220px;
}
@media screen and (max-width: 768px){
  .quality .quality-banner-img {
      width: 179px;
  }
}
.quality .quality-banner-desc {
  flex: 1;
}
.quality .quality-banner-text {
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1.6;
}
@media screen and (max-width: 768px){
  .quality .quality-banner-text {
      font-size: 14px;
  }
}
.quality .quality-banner-text strong {
  font-weight: bold;
}
.quality .quality-banner-text sup {
  font-size: 0.5em;
  vertical-align: text-top;
}
.quality .quality-banner-note {
  font-size: 10px;
  margin-top: 20px;
  letter-spacing: 0.04em;
  line-height: 1.3;
}
@media screen and (max-width: 768px){
  .quality .quality-banner-note {
      margin-top: 10px;
  }
}


/* add20230628 */
.page-features .features-content-btn .button-wrap {
  margin-top: 0;
}
.page-features .features-content-btn .button-wrap a {
  width: 294px;
  padding: 12px 30px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-btn .button-wrap a {
    width: 180px;
    padding: 8px 0;
    margin-bottom: 10px;
  }
}
.page-features .features-content-btn .button-wrap a span {
  font-size: 1.5rem;
  line-height: 2rem;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-btn .button-wrap a span {
    font-size: 1.1rem;
    line-height: 1.6rem;
  }
}
.page-features .features-content-list {
  margin: 30px 0;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-list {
    margin: 25px 0;
  }
}
.page-features .features-content-item:not(:last-of-type) {
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .page-features .features-content-item:not(:last-of-type) {
    margin-bottom: 15px;
  }
}

/* MV下CTA */
.mv-cta {
  margin: 0 calc(50% - 50vw) 0;
  background-color: #fff;
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .mv-cta {
    padding: 0 12px;
  }
}
.mv-cta-inner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1150px;
  border-bottom: 1px solid #9E9E9E;
  padding: 20px 0 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 11px 20px;
}
@media screen and (max-width: 768px) {
  .mv-cta-inner {
    padding: 11px 0 20px;
    flex-direction: column;
  }
}
.mv-cta-text {
  font-size: 1.6rem;
  line-height: 1.5;
  padding-left: 1.5em;
  text-indent: -1.5em;
}
@media screen and (max-width: 768px) {
  .mv-cta-text {
    font-size: 1.3rem;
    padding-left: 1.3em;
    text-indent: -1.3em;
  }
}
.mv-cta-text::before {
  content: "※";
  margin-right: 0.5em;
}
@media screen and (max-width: 768px) {
  .mv-cta-text::before {
    margin-right: 0.3em;
  }
}
.mv-cta-button {
  font-size: 1.4rem;
  background-color: #9E9E9E;
  border-radius: 40px;
  color: #fff;
  padding: 10px 15px;
  border: 1px solid #9E9E9E;
  transition: .2s;
}
@media screen and (max-width: 768px) {
  .mv-cta-button {
    font-size: 1.3rem;
    padding: 8px 15px;
  }
}
@media (hover: hover) {
  .mv-cta-button:hover {
    background-color: #fff;
    color: #111111;
    border: 1px solid #111111;
  }
}

