@charset "UTF-8";
body {
  font-size: 14px;
  line-height: 1.8em
}
.wfont {
  font-family: "Passion One", sans-serif;
  font-weight: 400;
  font-style: normal
}
@media only screen and (min-width:769px), print {
  body {
    font-size: 16px;
    line-height: 1.8em
  }
}
@media only screen and (min-width:1025px), print {
  body {
    font-size: 18px;
    line-height: 1.9em
  }
}
.font-xs {
  font-size: 12px;
  line-height: 1.8em
}
.font-sm {
  font-size: 13px;
  line-height: 1.8em
}
.font-md {
  font-size: 14px;
  line-height: 1.8em
}
.font-lg {
  font-size: 16px;
  line-height: 1.8em
}
.font-xl {
  font-size: 18px;
  line-height: 2em
}
.heading-xs {
  font-size: 20px;
  line-height: 1.6em
}
.heading-sm {
  font-size: 22px;
  line-height: 1.6em
}
.heading-md {
  font-size: 24px;
  line-height: 1.6em
}
.heading-lg {
  font-size: 26px;
  line-height: 1.6em
}
.heading-xl {
  font-size: 32px;
  line-height: 1.6em
}
sup, sub {
  font-size: 60%
}
.pc-hide {
  display: none !important
}
.sp-hide {
  display: inherit !important
}
@media only screen and (min-width:769px), print {
  .font-xs {
    font-size: 13px;
    line-height: 1.9em
  }
  .font-sm {
    font-size: 14px;
    line-height: 1.9em
  }
  .font-md {
    font-size: 15px;
    line-height: 1.9em
  }
  .font-lg {
    font-size: 16px;
    line-height: 1.9em
  }
  .font-xl {
    font-size: 18px;
    line-height: 1.9em
  }
  .heading-xs {
    font-size: 20px;
    line-height: 1.6em
  }
  .heading-sm {
    font-size: 22px;
    line-height: 1.6em
  }
  .heading-md {
    font-size: 28px;
    line-height: 1.6em
  }
  .heading-lg {
    font-size: 34px;
    line-height: 1.6em
  }
  .heading-xl {
    font-size: 40px;
    line-height: 1.6em
  }
  .pc-hide {
    display: inherit !important
  }
  .sp-hide {
    display: none !important
  }
}
@media only screen and (min-width:1025px), print {
  .font-xs {
    font-size: 14px;
    line-height: 1.9em
  }
  .font-sm {
    font-size: 16px;
    line-height: 1.9em
  }
  .font-md {
    font-size: 18px;
    line-height: 1.9em
  }
  .font-lg {
    font-size: 22px;
    line-height: 1.9em
  }
  .font-xl {
    font-size: 30px;
    line-height: 1.9em
  }
  .heading-xs {
    font-size: 32px;
    line-height: 1.6em
  }
  .heading-sm {
    font-size: 34px;
    line-height: 1.6em
  }
  .heading-md {
    font-size: 38px;
    line-height: 1.6em
  }
  .heading-lg {
    font-size: 44px;
    line-height: 1.6em
  }
  .heading-xl {
    font-size: 50px;
    line-height: 1.6em
  }
  .pc-hide {
    display: inherit !important
  }
  .sp-hide {
    display: none !important
  }
}
.s-inner {
  width: 100%;
  max-width: 1600px;
  min-width: 270px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 5%
}
.heading-main {
  color: #fff;
  width: 100%;
  height: 140px;
  text-align: center;
  background: #0065C9 url(../img/bg_blue.png) no-repeat center center / cover;
  display: table
}
.heading-main small {
  font-size: 40%;
  color: #fff;
  display: block;
  margin-bottom: .5em;
}
.heading-main h2 {
  display: table-cell;
  vertical-align: middle
}
.heading-sub {
  width: 80%;
  margin: 0 auto 1em auto;
  padding: .8em 0;
  background-image: linear-gradient(90deg, #459FE7 0 50%, #0065C9 50%);
  background-repeat: no-repeat;
  background-size: 100% 4px;
  background-position: bottom;
  text-align: center;
  font-weight: 700
}
.heading-sub2 {
  color: #fff;
  background-color: #0474E2;
  text-align: center;
  width: 100%;
  margin: 0 auto;
  padding: .6em 1em .8em 1em;
  position: relative;
  border-radius: 6px
}
.heading-sub2:after {
  border: solid transparent;
  content: '';
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  border-color: #fff;
  border-top-width: 24px;
  border-bottom-width: 24px;
  border-left-width: 24px;
  border-right-width: 24px;
  margin-left: -24px;
  border-top-color: #0474E2;
  top: 100%;
  left: 50%
}
@media only screen and (min-width:769px), print {
  .heading-main {
    height: 220px
  }
  .heading-sub {
    width: 430px
  }
}
.link-arrow {
  padding-left: 1.5em;
  background: url(../img/icon_arrow.svg) no-repeat left 0 center;
  background-size: 14px 14px
}
.btn-base {
  display: block;
  width: 100%;
  margin: 1em auto;
  text-align: center;
  text-decoration: none;
  font-weight: 700;
  transition: .3s;
  position: relative;
  overflow-wrap: break-word
}
.btn-base:after {
  content: "";
  display: block;
  width: .8em;
  height: .8em;
  position: absolute;
  right: 1.8em;
  top: 50%;
  transform: translateY(-50%);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat
}
.btn-base.ico-arrow:after {
  background-image: url(../img/icon_arrow_w.svg)
}
.btn-normal {
  border-radius: 45px;
  color: rgb(51, 51, 51);
  border: 1px #ccc solid;
  padding: .5em 1em
}
.btn-normal.white {
  color: #fff;
  border: 1px #fff solid
}
.btn-normal.white.ico-arrow:after {
  background-image: url(../img/icon_arrow.svg)
}
.btn-normal:hover {
  text-decoration: none;
  background-color: #EBF4FD;
  color: rgb(51, 51, 51)
}
.btn-attention {
  background: transparent linear-gradient(90deg, #F18D26FE 0%, #FD644F 100%) 0% 0% no-repeat padding-box;
  box-shadow: 0 0 20px #ccc;
  border-radius: 45px;
  color: #fff;
  height: 90px;
  line-height: 90px
}
.btn-attention:hover {
  text-decoration: none;
  letter-spacing: .3rem;
  transform: translateY(-4px);
  background: transparent linear-gradient(90deg, #F07A00FE 0%, #FF1F00 100%) 0% 0% no-repeat padding-box;
  box-shadow: 0 0 20px #F18D26FE
}
.btn-back {
  width: 70%;
  border-radius: 45px;
  color: rgb(51, 51, 51);
  border: 2px #ccc solid;
  padding: .5em 1em .5em 2em
}
.btn-back.white {
  color: #fff;
  border: 1px #fff solid
}
.btn-back:after {
  display: none
}
.btn-back:before {
  content: "";
  display: block;
  width: .8em;
  height: .8em;
  position: absolute;
  left: 1.8em;
  top: 50%;
  transform: translateY(-50%);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat
}
.btn-back.ico-arrow:before {
  background-image: url(../img/icon_arrow_back.svg)
}
.btn-back:hover {
  text-decoration: none;
  background-color: #EBF4FD;
  color: rgb(51, 51, 51)
}
@media only screen and (min-width:769px), print {
  .btn-base {
    width: 500px
  }
  .btn-back {
    width: 300px
  }
}
.mainv {
  width: 100%;
  background-color: #f5f5f5;
  background-position: center 35%;
  background-size: 60% auto;
  padding-top: 8%
}
.mainv .catch {
  display: inline-block;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  height: 46px;
  margin: 0 auto 14px auto;
  padding: 0 2%;
  line-height: 40px;
  font-size: 3.4vw;
  color: #0474E2;
  font-weight: 700;
  text-align: center;
  border-top: 2px solid #0474e2;
  border-bottom: 2px solid #0474e2;
  position: relative
}
.mainv .catch::after {
  position: absolute;
  top: 0;
  bottom: 0;
  content: '';
  display: block;
  width: 24px;
  height: 24px;
  background: url(../img/bg_catch_under-sp.png) no-repeat left bottom;
  background-size: 24px 24px;
  margin: 42px 0 0 40px
}
.mainv .title {
  font-size: 24vw;
  color: #0474E2;
  text-align: center;
  line-height: .8em;
  font-family: "Passion One", sans-serif;
  font-weight: 400;
  font-style: normal;
  margin-bottom: 0
}
.mainv .pic {
  display: block;
  width: 100%;
  height: 0;
  padding-top: 56%;
  background-image: url(../img/mainv.png);
  background-repeat: no-repeat;
  background-position: calc(50% + 3%) center;
  background-size: 70% auto
}
.mainv .lead {
  font-size: 16px;
  line-height: 2em;
  padding: 0 8% 1em 8%
}
.mainv .btn {
  padding: 0 8% 1em 8%
}
.mainv .btn a {
  width: 100% !important;
  height: 60px !important;
  line-height: 60px !important
}
@media only screen and (min-width:769px), print {
  .mainv {
    height: 620px;
    position: relative;
    padding-top: 0
  }
  .mainv .bg {
    height: 620px;
    opacity: 0;
    background-image: url(../img/mainv.png);
    background-repeat: no-repeat;
    background-position: calc(50% + 290px) center;
    background-size: 540px auto;
    -webkit-animation: zoom 1.6s 1 ease-out;
    animation: zoom 1.6s 1;
    animation-fill-mode: forwards
  }
  @keyframes zoom {
    0% {}
    50% {
      opacity: 0;
      bottom: -100px;
      transform: scale(.8)
    }
    100% {
      opacity: 1;
      bottom: 0;
      transform: scale(1)
    }
  }
  .mainv .catch, .mainv .title, .mainv .lead, .mainv .btn {
    position: absolute;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    left: calc(50% - 180px);
    width: 400px
  }
  .mainv .catch {
    top: 60px;
    height: 60px;
    line-height: 56px;
    font-size: 16px;
    border-top: 3px solid #0474e2;
    border-bottom: 3px solid #0474e2
  }
  .mainv .catch::after {
    background: url(../img/bg_catch_under.png) no-repeat left bottom;
    background-size: 24px 24px;
    margin: 54px 0 0 40px
  }
  .mainv .title {
    font-size: 140px;
    top: 130px
  }
  .mainv .pic {
    display: none
  }
  .mainv .lead {
    font-size: 16px;
    top: 280px;
    padding: 0 15px
  }
  .mainv .btn {
    top: 460px;
    padding: 0
  }
  .mainv .btn a {
    height: 50px !important;
    line-height: 50px !important;
    font-size: 20px
  }
}
@media only screen and (min-width:1000px), print {
  .mainv .bg {
    background-position: calc(50% + 320px) center;
    background-size: 540px auto
  }
  .mainv .catch, .mainv .title, .mainv .lead, .mainv .btn {
    left: calc(50% - 200px);
    width: 480px
  }
  .mainv .catch {
    top: 60px;
    font-size: 18px
  }
  .mainv .title {
    font-size: 160px;
    top: 140px
  }
  .mainv .lead {
    top: 320px;
    font-size: 18px
  }
  .mainv .btn {
    top: 500px
  }
}
@media only screen and (min-width:1200px), print {
  .mainv {
    height: 720px
  }
  .mainv .bg {
    height: 720px;
    background-position: calc(50% + 360px) center;
    background-size: 740px auto
  }
  .mainv .catch, .mainv .title, .mainv .lead, .mainv .btn {
    left: calc(50% - 300px);
    width: 520px
  }
  .mainv .catch {
    top: 120px;
    font-size: 20px
  }
  .mainv .catch::after {
    margin: 54px 0 0 40px
  }
  .mainv .title {
    font-size: 178px;
    top: 190px
  }
  .mainv .lead {
    font-size: 18px;
    top: 370px
  }
  .mainv .btn {
    top: 530px
  }
}
@media only screen and (min-width:1400px), print {
  .mainv .index {
    background-position: calc(50% + 450px) center;
    background-size: 840px auto
  }
  .mainv .catch, .mainv .title, .mainv .lead, .mainv .btn {
    left: calc(50% - 340px);
    width: 620px
  }
  .mainv .catch::after {
    margin: 54px 0 0 60px
  }
}
.problem {
  padding: 2% 0
}
.problem h2 {
  text-align: left;
  margin-bottom: .8em
}
.problem h2 strong {
  color: #0474E2
}
.problem-wrap ul {
  margin: 0;
  padding: 0;
  list-style: none;
  width: 100%
}
.problem-wrap ul li {
  padding: .8em 0 .8em 2em;
  border-bottom: 1px solid #ccc;
  background-position: .5em 1.3em;
  background-repeat: no-repeat;
  background-size: 1em 1em;
  overflow-wrap: break-word;
  background-image: url(../img/icon_check.svg)
}
.problem p {
  text-align: left;
  margin: 2em 0 3em 0
}
.problem p span {
  padding-bottom: 2px;
  background: linear-gradient(transparent 94%, #9DD4FF 94%)
}
@media only screen and (min-width:769px), print {
  .problem h2 {
    text-align: center
  }
  .problem-wrap {
    display: flex
  }
  .problem-wrap ul {
    margin: 0 20px
  }
  .problem-wrap ul li {
    padding: 1em 0 1em 2em;
    background-position: .5em 1.5em
  }
  .problem p {
    text-align: center
  }
  .problem p span {
    padding-bottom: 10px
  }
}
.servicemenu {
  padding: 0 0 2% 0;
  background-color: #EBF4FD
}
.servicemenu h3 {
  margin: 2em 0 .5em 0;
  text-align: left
}
.servicemenu p {
  text-align: left;
  margin-bottom: 2em
}
.servicemenu-wrap {
  margin: 2em 0 2em 0;
  background-color: #fff;
  border-radius: 20px;
  padding: 3%;
  text-align: center
}
.servicemenu-wrap h4 {
  margin-bottom: 1em
}
.servicemenu-wrap ul {
  list-style: none;
  display: flex;
  flex-basis: auto;
  justify-content: space-between;
  flex-direction: column;
  width: 90%;
  margin: 0 auto 1em auto;
  padding: 0
}
.servicemenu-wrap ul li {
  background-color: #F5F5F5;
  position: relative;
  margin: 0 0 60px 0;
  width: 100%;
  padding: 2em 0;
  box-shadow: 0 1px 4px #ccc
}
.servicemenu-wrap ul li:before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 20px 0 0;
  border-color: #459FE7 transparent transparent transparent
}
.servicemenu-wrap ul li:after {
  content: '';
  display: inline-block;
  width: 26px;
  height: 26px;
  background-size: contain;
  background: url(../img/icon_plus.png) no-repeat;
  position: absolute;
  top: calc(100% + 13px);
  right: calc(50% - 13px);
  margin-top: .4em
}
.servicemenu-wrap ul li:last-child {
  margin: 0
}
.servicemenu-wrap ul li:last-child::after {
  content: none;
  width: 0
}
.servicemenu-wrap ul li strong {
  color: #0474E2;
  display: block;
  margin-bottom: .2em
}
.servicemenu .notes {
  list-style: none;
  margin: 0 0 2em 0;
  padding: 0
}
.servicemenu .notes li {
  margin-bottom: .4em
}
@media only screen and (min-width:769px), print {
  .servicemenu h3 {
    text-align: center
  }
  .servicemenu p {
    text-align: center
  }
  .servicemenu-wrap ul {
    flex-direction: row
  }
  .servicemenu-wrap ul li {
    margin: 0 60px 0 0
  }
  .servicemenu-wrap ul li:after {
    top: calc(50% - 15px);
    right: -42px
  }
}
.flow {
  padding: 3% 0
}
.flow p {
  text-align: center;
  margin: 50px 0 20px 0;
  padding: 0 5%
}
.flow img {
  width: 100%;
  max-width: 1400px;
  height: auto
}
.flow .notes {
  list-style: none;
  margin: 0 0 4em 0;
  padding: 0
}
.flow .notes li {
  margin-bottom: .4em
}
.flow .point {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0
}
.flow .point li {
  width: 100%
}
.flow .point li strong {
  display: inline-block !important;
  background: #EBF4FD 0% 0% no-repeat padding-box;
  border-radius: 20px;
  text-align: center;
  width: 100%;
  margin-bottom: .8em;
  padding: 1.5em 0
}
.flow .point li:last-child strong {
  padding: 2.45em 0
}
.flow .point li span {
  display: block;
  margin-bottom: 1.4em;
  font-size: 80%;
  line-height: 1.9em
}
@media only screen and (min-width:769px), print {
  .flow .point li {
    width: 50%;
    padding: 0 20px
  }
}
.number {
  padding: 3% 0
}
.number h3 {
  text-align: left;
  margin-bottom: 2em
}
.number img {
  width: 100%;
  height: auto
}
.number ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 1em 0;
  padding: 0
}
.number ul li {
  width: 100%;
  margin-bottom: 1em
}
.number ul li img {
  width: 100%;
  height: auto
}
.number .notes {
  text-align: left
}
@media only screen and (min-width:769px), print {
  .number h3 {
    text-align: center
  }
  .number ul li {
    width: 50%;
    padding: 0 20px
  }
  .number .notes {
    text-align: center
  }
}
.cando {
  padding: 0 0 6% 0
}
.cando h2 {
  font-weight: 700
}
.cando h3 {
  margin: 2em 0 .5em 0;
  text-align: left
}
.cando p {
  text-align: left;
  margin-bottom: 2em
}
.cando_wrap {
  border: 4px solid #EDEDED;
  padding: 5%
}
.cando_wrap.sec {
  border-top: none
}
.cando_wrap h4 {
  text-align: center;
  color: #0474E2;
  font-weight: 400;
  margin: 0 0 1em 0
}
.cando_wrap h5 {
  margin-bottom: 2em
}
.cando_wrap p {
  margin: 0;
  padding: 0
}
.cando_wrap ol {
  list-style: none;
  margin: 0;
  padding: 0
}
.cando_wrap ol li {
  display: flex;
  margin: 0 0 2em 0;
  padding: 0 1em 1.5em 1em;
  border-bottom: 1px solid #ccc
}
.cando_wrap ol li:last-child {
  border: none
}
.cando_wrap ol li p.num {
  width: 70px
}
.cando_wrap ol li p.num span {
  display: inline-block;
  font-size: 56px;
  font-family: "Passion One", sans-serif;
  color: #459FE7;
  padding-top: 15px
}
.cando_wrap ol li p.text {
  text-align: left;
  width: calc(100% - 70px)
}
.cando_wrap p img {
  width: 100%;
  height: auto
}
@media only screen and (min-width:769px), print {
  .cando h3 {
    text-align: center
  }
  .cando p {
    text-align: center
  }
  .cando_wrap ol {
    display: flex;
    flex-wrap: wrap
  }
  .cando_wrap ol li {
    width: 45%;
    margin: 0 auto 2em auto;
    padding: 0 0 2em 0;
    border: none
  }
  .cando_wrap ol li.border {
    border-bottom: 1px solid #ccc
  }
  .cando_wrap ol li p.num {
    width: 110px
  }
  .cando_wrap ol li p.num span {
    font-size: 80px;
    padding-top: 20px
  }
  .cando_wrap ol li p.text {
    text-align: left;
    margin-bottom: 0;
    width: calc(100% - 110px)
  }
}
.platform {
  padding: 3% 0;
  background-color: #EBF4FD
}
.platform h2 {
  margin: 0 0 1.5em 0;
  text-align: center;
  color: #0474E2
}
.platform h2 small {
  color: #0474E2
}
.platform h3 {
  margin: 1em 0 1.5em 0;
  text-align: left;
  font-weight: 700
}
.platform h3 span {
  padding-bottom: 2px;
  background: linear-gradient(transparent 94%, #9DD4FF 94%)
}
.platform p {
  text-align: center
}
.platform .platform_play {
  background: #FFF 0% 0% no-repeat padding-box;
  box-shadow: 0 0 30px #0000001A;
  border-radius: 20px;
  width: 90%;
  margin: 0 auto 2em auto;
  padding: 2em
}
.platform .platform_play img {
  width: 100%;
  height: auto
}
@media only screen and (min-width:769px), print {
  .platform h2 {
    text-align: center
  }
  .platform h3 {
    text-align: center
  }
  .platform p {
    text-align: center
  }
  .platform p span {
    padding-bottom: 10px
  }
  .platform .platform_play {
    width: 70%
  }
}
.merit {
  padding: 3% 0;
  background-color: #0474E2
}
.merit h2 {
  color: #fff;
  margin: 1em 0 1.5em 0;
  text-align: center
}
.merit_wrap ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0
}
.merit_wrap ul li {
  width: 46%;
  margin: 0 2% 2% 2%;
  background-color: #fff;
  border-radius: 20px;
  box-shadow: 0 3px 20px #00000029;
  text-align: center
}
.merit_wrap ul li span {
  display: block;
  width: 80%;
  margin: 1em auto;
  padding: 0 0 1em 0;
  border-bottom: 1px solid #ccc
}
.merit_wrap ul li span img {
  width: 50%;
  height: auto;
  margin: 0 auto;
  display: block
}
.merit_wrap ul li strong {
  display: block;
  padding: 0 0 1.5em 0;
  font-size: 13px
}
@media only screen and (min-width:769px), print {
  .merit h2 {
    text-align: center
  }
  .merit_wrap ul li {
    width: 29%;
    margin: 0 2% 2% 2%
  }
  .merit_wrap ul li strong {
    font-size: 16px
  }
}
@media only screen and (min-width:1025px), print {
  .merit_wrap ul li strong {
    font-size: 20px
  }
}
.reason {
  padding: 3% 0;
  background-color: #F5F5F5
}
.reason h2 {
  margin: 1em 0 1.2em 0;
  text-align: center
}
.reason_wrap ol {
  list-style: none;
  margin: 0;
  padding: 0
}
.reason_wrap ol li {
  display: flex;
  margin: 0 0 2em 0;
  padding: 2em 2em 1em 2em;
  background: #FFF;
  box-shadow: 0 3px 20px #ccc;
  border-radius: 20px
}
.reason_wrap ol li p.num {
  width: 70px
}
.reason_wrap ol li p.num span {
  display: inline-block;
  font-size: 56px;
  font-family: "Passion One", sans-serif;
  color: #459FE7;
  padding-top: 15px
}
.reason_wrap ol li p.text {
  text-align: left;
  width: calc(100% - 70px)
}
@media only screen and (min-width:769px), print {
  .reason h2 {
    text-align: center
  }
  .reason_wrap ol li {
    padding: 3em 3em
  }
  .reason_wrap ol li p.num {
    width: 90px
  }
  .reason_wrap ol li p.num span {
    font-size: 80px
  }
  .reason_wrap ol li p.text {
    text-align: left;
    margin-bottom: 0;
    width: calc(100% - 90px)
  }
}
.case {
  background-color: #0474E2
}
.case_wrap .photo {
  width: 100%;
  height: 300px;
  background: url(../img/img_case.jpg) no-repeat center center;
  background-size: cover
}
.case_wrap .text {
  width: 100%;
  padding: 2em 0;
  text-align: center;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column
}
.case_wrap .text h2 {
  margin: 0 0 .5em 0
}
.case_wrap .text h2 span {
  display: block;
  color: #fff
}
.case_wrap .text h2:after {
  content: '';
  display: block;
  width: 60%;
  border-bottom: 1px solid #fff;
  margin: .6em auto
}
.case_wrap .text dl {
  margin: 0;
  padding: 0
}
.case_wrap .text dl dt {
  margin: 0 0 1.5em 0;
  padding: 0
}
.case_wrap .text dl dd {
  margin: 0 0 .5em 0;
  padding: 0
}
.case_wrap .text dl dd .btn-normal {
  width: 100%
}
@media only screen and (min-width:769px), print {
  .case_wrap {
    display: flex
  }
  .case_wrap .photo {
    width: 50%;
    height: auto
  }
  .case_wrap .text {
    width: 50%;
    padding: 3em 0
  }
}
@media only screen and (min-width:1025px), print {
  .case_wrap .text {
    width: 50%;
    padding: 6em 0
  }
}
.support {
  padding: 3% 0
}
.support p {
  text-align: left;
  margin-bottom: 2em
}
.support_wrap ol {
  list-style: none;
  margin: 0;
  padding: 0
}
.support_wrap ol li {
  display: flex;
  background: url(../img/bg_supportnum.png) top left repeat-y;
  margin: 0;
  padding: 0
}
.support_wrap ol li:last-child {
  background: none
}
.support_wrap ol li p.num {
  width: 80px
}
.support_wrap ol li p.num span {
  display: block;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  line-height: 60px;
  font-size: 30px;
  font-family: "Passion One", sans-serif;
  color: #fff;
  text-align: center;
  background: #459FE7 0% 0% no-repeat padding-box
}
.support_wrap ol li p.text {
  text-align: left;
  margin-bottom: 2em;
  width: calc(100% - 80px)
}
@media only screen and (min-width:769px), print {
  .support p {
    text-align: center
  }
  .support_wrap {
    padding: 0 10%
  }
}
.qa {
  padding: 3% 0
}
.qa h2 {
  margin-bottom: 1.5em
}
.qa .qa_wrap ul {
  list-style: none;
  margin: 0;
  padding: 0
}
.qa .qa_wrap ul li {
  margin-bottom: 2em
}
.qa .qa_wrap ul li h3 {
  background-color: #EBF4FD;
  border-radius: 20px;
  padding: 1em 2em
}
.qa .qa_wrap ul li h3 span {
  color: #459FE7;
  font-family: "Passion One", sans-serif;
  font-size: 1.4em;
  margin-right: .5em
}
.qa .qa_wrap ul li p {
  margin-bottom: 1em;
  padding: 0 1em
}
@media only screen and (min-width:769px), print {
  .qa .qa_wrap ul li p {
    padding: 0 3em
  }
}
.case_mainv {
  text-align: center;
  color: #fff;
  background-color: #0474E2
}
.case_mainv .btn-back {
  display: none
}
.case_mainv .title {
  font-size: 30px;
  margin-bottom: .5em;
  padding-top: 1em
}
.case_mainv .title small {
  font-size: 14px;
  color: #9DD4FF;
  display: block;
  margin: .5em 0 0 0
}
.case_mainv .pic {
  margin-bottom: 0em
}
.case_mainv .pic img {
  width: 100%;
  height: auto
}
.case_mainv .company {
  color: #222;
  width: 90%;
  background-color: #fff;
  border-radius: 20px 20px 0 0;
  font-size: 16px;
  margin: 0 auto;
  padding: 1em 1em
}
.case_mainv .company small {
  font-weight: 700;
  color: #222
}
@media only screen and (min-width:769px), print {
  .case_mainv {
    position: relative;
    height: 800px;
    margin-bottom: 0;
    background-color: #fff
  }
  .case_mainv .bg {
    height: 400px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background-color: #0474E2
  }
  .case_mainv .btn-back {
    position: absolute;
    top: 20px;
    right: 5%;
    display: block;
    width: 240px !important;
    font-size: 16px;
    padding: .5em 0 .5em 1.5em
  }
  .case_mainv .title {
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    font-size: 38px;
    margin: 0;
    padding: 0
  }
  .case_mainv .title small {
    font-size: 20px;
    color: #9DD4FF;
    display: block;
    margin: .5em 0 0 0;
    4
  }
  .case_mainv .pic {
    position: absolute;
    top: 150px;
    left: 0;
    right: 0;
    width: 100%;
    max-width: 1600px;
    height: 640px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 5%;
    background: url(../img/img_casemain.png) no-repeat top center;
    background-size: cover
  }
  .case_mainv .pic img {
    display: none
  }
  .case_mainv .company {
    width: 60%;
    font-size: 22px;
    position: absolute;
    bottom: 30px;
    left: 0;
    right: 0;
    margin: 0 auto;
    border-radius: 40px
  }
}
@media only screen and (min-width:1025px), print {
  .case_mainv {
    height: 1000px
  }
  .case_mainv .company {
    font-size: 26px
  }
  .case_mainv .pic {
    height: 840px
  }
  .case_mainv .company {
    bottom: 60px
  }
}
@media only screen and (min-width:1600px), print {
  .case_mainv {
    height: 1000px;
    margin-bottom: 60px
  }
  .case_mainv .company {
    width: 60%;
    bottom: 0
  }
}
.case_lead {
  margin-top: 3em;
  padding-bottom: 2em
}
.case_lead_wrap {
  border: 4px solid #EEE;
  border-radius: 20px;
  padding: 2em
}
.case_lead_wrap dl dt {
  margin-bottom: .6em
}
.case_lead_wrap p {
  text-align: center
}
.case_lead_wrap p img {
  width: 80%;
  height: auto
}
@media only screen and (min-width:769px), print {
  .case_lead {}
  .case_lead_wrap {
    margin: 0 4%;
    padding: 2em 2em
  }
}
@media only screen and (min-width:1025px), print {
  .case_lead_wrap {
    margin: 0 8%;
    padding: 2em 4em;
    display: flex
  }
  .case_lead_wrap dl {
    width: 100%;
    flex: 1
  }
  .case_lead_wrap p {
    flex-basis: 360px;
    margin-left: 5%
  }
  .case_lead_wrap p img {
    width: 100%;
    height: auto
  }
}
.case_change {
  padding-bottom: 3em
}
.case_change_wrap p {
  font-weight: 700;
  margin-bottom: .9em
}
.case_change_wrap .before, .case_change_wrap .after {
  margin-bottom: 1em
}
.case_change_wrap .after p {
  color: #0474E2
}
.case_change_wrap dl {
  margin-bottom: .5em;
  padding-bottom: .5em;
  display: flex
}
.case_change_wrap dl dt, .case_change_wrap dl dd {
  padding: .1em 0 1em 0;
  border-bottom: 1px solid #ccc
}
.case_change_wrap dl dt span {
  display: inline-block;
  width: 6em;
  text-align: center;
  color: #fff
}
.case_change_wrap .before dl dt span {
  background-color: #222
}
.case_change_wrap .after dl dt span {
  background-color: #0474E2
}
.case_change_wrap dl dd {
  width: 100%;
  flex: 1;
  padding-left: 1em
}
@media only screen and (min-width:769px), print {
  .case_change {}
  .case_change_wrap {
    margin: 0 4%;
    display: flex;
    flex-wrap: wrap
  }
  .case_change_wrap .before {
    width: 54%
  }
  .case_change_wrap .after {
    width: 46%
  }
  .case_change_wrap .before dl {
    width: 95%
  }
  .case_change_wrap .after dl {
    width: 95%
  }
  .case_change_wrap .before dl:after {
    content: '▶';
    display: block;
    font-size: 1.5em;
    color: #ddd;
    margin-left: 1.2em;
    border: none
  }
  .case_change_wrap dl dt, .case_change_wrap dl dd {
    height: 4em;
    line-height: 1.4em;
    padding-bottom: 3em
  }
}
@media only screen and (min-width:1450px), print {
  .case_change_wrap dl dt, .case_change_wrap dl dd {
    height: 3em
  }
}
@media only screen and (min-width:1025px), print {
  .case_change_wrap {
    margin: 0 8%
  }
}
.case_article {
  padding: 3% 0
}
.case_article#con01, .case_article#con03 {
  background-color: #EBF4FD
}
.case_article#con05 {
  background-color: #0065C9
}
.heading-case {
  position: relative;
  text-align: center;
  width: 100%;
  height: 100px;
  margin: 5% auto 0 auto
}
.heading-case::before {
  content: '';
  position: absolute;
  top: 15px;
  left: 0;
  display: block;
  width: 19px;
  height: 55px;
  background-size: contain;
  background: url(../img/icon_brackets_left.svg) no-repeat
}
.heading-case::after {
  content: '';
  position: absolute;
  top: 15px;
  right: 0;
  display: block;
  width: 19px;
  height: 55px;
  background-size: contain;
  background: url(../img/icon_brackets_right.svg) no-repeat
}
.heading-case strong {
  width: 100%;
  position: absolute;
  top: 30px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 22px;
  color: #0474E2;
  z-index: 1
}
.heading-case span {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  font-size: 100px;
  font-family: "Passion One", sans-serif;
  font-weight: 400;
  font-style: normal;
  z-index: 0
}
.case_article#con02 .heading-case span, .case_article#con04 .heading-case span {
  color: #F5F5F5
}
.case_article#con05 {
  color: #fff
}
.case_article#con05 .heading-case strong {
  color: #fff
}
.case_article#con05 .heading-case span {
  color: #0A5EAD
}
.case_article#con05 .heading-case::before {
  background: url(../img/icon_brackets_left_w.svg) no-repeat
}
.case_article#con05 .heading-case::after {
  background: url(../img/icon_brackets_right_w.svg) no-repeat
}
@media only screen and (min-width:769px), print {
  .heading-case {
    width: 360px;
    height: 200px;
    margin: 0 auto
  }
  .heading-case::before, .heading-case::after {
    top: 64px
  }
  .heading-case strong {
    top: 70px;
    font-size: 30px
  }
  .heading-case span {
    top: -30px;
    font-size: 200px
  }
}
.case_article .catch {
  margin-bottom: .8em
}
.case_article p {
  line-height: 2em;
  margin-bottom: 1em
}
.case_article p img {
  width: 100%;
  height: auto
}
.case_article p span {
  display: block;
  text-align: center;
  margin: 1em 0
}
.case_article p span strong {
  font-size: 1.4em
}
@media only screen and (min-width:769px), print {
  .case_article {
    padding: 3% 8%
  }
  .case_article .catch {
    font-size: 26px;
    line-height: 1.8em
  }
}
@media only screen and (min-width:1300px), print {
  .case_article_wrap {
    display: flex
  }
  .case_article p {
    line-height: 2em;
    margin-bottom: 2.8em
  }
  .case_article_wrap .left {
    width: 50%
  }
  .case_article_wrap .right {
    width: 50%
  }
  .case_article_wrap .right .catch, .case_article_wrap .right .text {
    padding-left: 10%
  }
  .case_article_wrap .left .catch, .case_article_wrap .left .text {
    padding-right: 10%
  }
  .case_article#con02 .case_article_wrap .left {
    width: 400px
  }
  .case_article#con02 .case_article_wrap .right {
    width: 100%;
    flex: 1
  }
  .case_article#con02 .right .text {
    padding-top: .8em;
    padding-left: 0
  }
  .case_article#con05 .con05_wrap {
    padding: 0 15%
  }
}
.closing {
  padding: 12% 0;
  background-color: #F5F5F5
}
.closing h2 {
  text-align: center;
  margin: 0 0 .5em 0
}
.closing p {
  text-align: left;
  margin: 0 0 2.5em 0
}
.closing p.btn {
  margin: 4em 0 0 0
}
@media only screen and (min-width:769px), print {
  .closing {
    padding: 6% 0
  }
  .closing p {
    text-align: center
  }
}
.floatfooter {
  background: transparent linear-gradient(270deg, #4D5967 0%, #6C839D 100%) 0% 0% no-repeat padding-box;
  position: fixed;
  z-index: 1000;
  bottom: 0;
  width: 100%;
  height: 0;
  transition: .4s
}
.floatfooter.fixed {
  height: 140px
}
.floatfooter .s-inner {
  display: flex;
  flex-direction: column
}
.floatfooter .f-copy {
  color: #fff;
  font-weight: 700;
  text-align: center;
  width: 100%;
  margin: 1em 0 0 0;
  padding: 0
}
.floatfooter .f-link {
  width: 100%;
  margin: 0;
  padding: 0
}
@media only screen and (min-width:769px), print {
  .floatfooter.fixed {
    height: 90px
  }
  .floatfooter .s-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row
  }
  .floatfooter .f-copy {
    width: 50%;
    font-size: 16px;
    margin: 0;
    padding: 0
  }
  .floatfooter .f-link {
    width: 50%;
    margin: 0;
    padding: 0
  }
  .floatfooter .f-link .btn-float {
    width: 90%
  }
}
@media only screen and (min-width:1025px), print {
  .floatfooter .f-copy {
    font-size: 20px
  }
}
.btn-float {
  background: transparent linear-gradient(90deg, #F18D26FE 0%, #FD644F 100%) 0% 0% no-repeat padding-box;
  box-shadow: 0 0 10px #666;
  border-radius: 1.5em;
  color: #fff;
  height: 3em;
  line-height: 3em
}
.btn-float:hover {
  text-decoration: none;
  background: transparent linear-gradient(90deg, #F07A00FE 0%, #FF1F00 100%) 0% 0% no-repeat padding-box
}
#page-top a {
  color: #fff;
  text-align: center;
  display: block;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.3s
}
#page-top a:hover {
  background: #777
}