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

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
button,
textarea,
p,
blockquote,
th {
  font-family: Helvetica, Arial, 'Microsoft JhengHei', sans-serif !important;
}

img,
object,
embed,
video {
  max-width: 100%;
}

.ie6 img {
  width: 100%;
}

body {
  color: #424242;
  background: #a8d0fb url(../images/body_bg.png) repeat/240px auto;
  background-image: -webkit-image-set(url(../images/body_bg.png) 1x, url(../images/body_bg@2x.png) 2x);
  background-image: image-set(url(../images/body_bg.png) 1x, url(../images/body_bg@2x.png) 2x);
  font-size: 15px;
  min-width: 320px;
  overflow-x: hidden;
}

.cp-tips {
  width: 100%;
  line-height: 1.6;
  text-align: center;
  color: #996600;
  background-color: #ffefc6;
  padding: 10px;
  font-size: 16px;
}

.cp-tips p {
  margin: 0;
}

.cp-tips a {
  color: #f75c61;
  text-decoration: underline;
}

.cp-tips .cp-tips-close {
  position: absolute;
  top: 10px;
  right: 10px;
  display: block;
  width: 22px;
  height: 22px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  cursor: pointer;
}

.cp-tips .cp-tips-close:before {
  content: '';
  position: absolute;
  width: 100%;
  border-top: 1px solid #996600;
  top: 50%;
  left: 0;
}

.cp-tips .cp-tips-close:after {
  content: '';
  position: absolute;
  height: 100%;
  border-left: 1px solid #996600;
  top: 0;
  left: 50%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.4;
}

p {
  line-height: 1.4;
}

.pt-0,
.p-0,
.py-0 {
  padding-top: 0px;
}

.pb-0,
.p-0,
.py-0 {
  padding-bottom: 0px;
}

.pl-0,
.p-0,
.px-0 {
  padding-left: 0px;
}

.pr-0,
.p-0,
.px-0 {
  padding-right: 0px;
}

.mt-0,
.m-0,
.my-0 {
  margin-top: 0px;
}

.mb-0,
.m-0,
.my-0 {
  margin-bottom: 0px;
}

.ml-0,
.m-0,
.mx-0 {
  margin-left: 0px;
}

.mr-0,
.m-0,
.mx-0 {
  margin-right: 0px;
}

.pt-1,
.p-1,
.py-1 {
  padding-top: 10px;
}

.pb-1,
.p-1,
.py-1 {
  padding-bottom: 10px;
}

.pl-1,
.p-1,
.px-1 {
  padding-left: 10px;
}

.pr-1,
.p-1,
.px-1 {
  padding-right: 10px;
}

.mt-1,
.m-1,
.my-1 {
  margin-top: 10px;
}

.mb-1,
.m-1,
.my-1 {
  margin-bottom: 10px;
}

.ml-1,
.m-1,
.mx-1 {
  margin-left: 10px;
}

.mr-1,
.m-1,
.mx-1 {
  margin-right: 10px;
}

.pt-2,
.p-2,
.py-2 {
  padding-top: 20px;
}

.pb-2,
.p-2,
.py-2 {
  padding-bottom: 20px;
}

.pl-2,
.p-2,
.px-2 {
  padding-left: 20px;
}

.pr-2,
.p-2,
.px-2 {
  padding-right: 20px;
}

.mt-2,
.m-2,
.my-2 {
  margin-top: 20px;
}

.mb-2,
.m-2,
.my-2 {
  margin-bottom: 20px;
}

.ml-2,
.m-2,
.mx-2 {
  margin-left: 20px;
}

.mr-2,
.m-2,
.mx-2 {
  margin-right: 20px;
}

.pt-3,
.p-3,
.py-3 {
  padding-top: 30px;
}

.pb-3,
.p-3,
.py-3 {
  padding-bottom: 30px;
}

.pl-3,
.p-3,
.px-3 {
  padding-left: 30px;
}

.pr-3,
.p-3,
.px-3 {
  padding-right: 30px;
}

.mt-3,
.m-3,
.my-3 {
  margin-top: 30px;
}

.mb-3,
.m-3,
.my-3 {
  margin-bottom: 30px;
}

.ml-3,
.m-3,
.mx-3 {
  margin-left: 30px;
}

.mr-3,
.m-3,
.mx-3 {
  margin-right: 30px;
}

.pt-4,
.p-4,
.py-4 {
  padding-top: 40px;
}

.pb-4,
.p-4,
.py-4 {
  padding-bottom: 40px;
}

.pl-4,
.p-4,
.px-4 {
  padding-left: 40px;
}

.pr-4,
.p-4,
.px-4 {
  padding-right: 40px;
}

.mt-4,
.m-4,
.my-4 {
  margin-top: 40px;
}

.mb-4,
.m-4,
.my-4 {
  margin-bottom: 40px;
}

.ml-4,
.m-4,
.mx-4 {
  margin-left: 40px;
}

.mr-4,
.m-4,
.mx-4 {
  margin-right: 40px;
}

.pt-5,
.p-5,
.py-5 {
  padding-top: 50px;
}

.pb-5,
.p-5,
.py-5 {
  padding-bottom: 50px;
}

.pl-5,
.p-5,
.px-5 {
  padding-left: 50px;
}

.pr-5,
.p-5,
.px-5 {
  padding-right: 50px;
}

.mt-5,
.m-5,
.my-5 {
  margin-top: 50px;
}

.mb-5,
.m-5,
.my-5 {
  margin-bottom: 50px;
}

.ml-5,
.m-5,
.mx-5 {
  margin-left: 50px;
}

.mr-5,
.m-5,
.mx-5 {
  margin-right: 50px;
}

.pt-6,
.p-6,
.py-6 {
  padding-top: 60px;
}

.pb-6,
.p-6,
.py-6 {
  padding-bottom: 60px;
}

.pl-6,
.p-6,
.px-6 {
  padding-left: 60px;
}

.pr-6,
.p-6,
.px-6 {
  padding-right: 60px;
}

.mt-6,
.m-6,
.my-6 {
  margin-top: 60px;
}

.mb-6,
.m-6,
.my-6 {
  margin-bottom: 60px;
}

.ml-6,
.m-6,
.mx-6 {
  margin-left: 60px;
}

.mr-6,
.m-6,
.mx-6 {
  margin-right: 60px;
}

.row {
  margin-left: -15px;
  margin-right: -15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.row > [class^="col-"] {
  padding-left: 15px;
  padding-right: 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.row.smmargin {
  margin-left: -5px;
  margin-right: -5px;
}

.row.smmargin > [class^="col-"] {
  padding-left: 5px;
  padding-right: 5px;
}

.row .col-2 {
  width: 16.66%;
}

.row .col-3 {
  width: 25%;
}

.row .col-4 {
  width: calc(100% / 3);
}

.row .col-5 {
  width: 41.66%;
}

.row .col-6 {
  width: 50%;
}

.row .col-7 {
  width: 58.34%;
}

.row .col-8 {
  width: calc(100% * 2 / 3);
}

.row .col-9 {
  width: 75%;
}

.row .col-12 {
  width: 100%;
}

/* set */
.text-hidden {
  text-indent: -9999px;
  height: 0;
}

.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.nowrap {
  white-space: nowrap;
}

.d-block {
  display: block;
}

.all-content {
  position: relative;
  overflow-x: hidden;
  font-size: 1.2em;
}

.n_header {
  position: absolute;
  z-index: 2;
  top: 30px;
  left: 30px;
}

.n_header img {
  width: 124px;
  height: 40px;
}

.container {
  width: 740px;
  max-width: 100%;
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
}

.main_top {
  width: 100%;
  position: relative;
  height: 600px;
  z-index: 1;
  background: url(../images/banner.png) no-repeat center bottom/1920px auto;
  background-image: -webkit-image-set(url(../images/banner.png) 1x, url(../images/banner@2x.png) 2x);
  background-image: image-set(url(../images/banner.png) 1x, url(../images/banner@2x.png) 2x);
}

.section_title {
  margin-bottom: 30px;
}

.section_title > * {
  display: inline-block;
  width: 360px;
  max-width: 75%;
  color: #fff;
  padding: 5px 10px;
  border-radius: 50em;
  font-size: 1.4em;
  border: 2px solid #fff;
  background: #4f92e3;
}

.case {
  margin-bottom: 2em;
}

.case p {
  font-size: 1.1em;
  line-height: 1.8;
}

.case p span {
  display: inline-block;
  margin: 0 5px;
  color: #637e9e;
  padding: 6px;
  background: #f9c845;
  border-radius: 3px;
  font-weight: bold;
  font-size: 1.2em;
  line-height: 1;
}

.case p b {
  color: #f21879;
  font-size: 1.2em;
}

.form-title {
  position: relative;
  background: url(../images/form_title_bg.png) no-repeat center bottom;
  background-image: -webkit-image-set(url(../images/form_title_bg.png) 1x, url(../images/form_title_bg@2x.png) 2x);
  background-image: image-set(url(../images/form_title_bg.png) 1x, url(../images/form_title_bg@2x.png) 2x);
  background-size: 70% 100%;
  padding: 30px 20px;
  text-align: center;
}

.form-title img {
  max-width: 50%;
}

.form-title .i01 {
  position: absolute;
  bottom: -25px;
  left: 80px;
}

.video_section {
  position: relative;
  padding: 4em 0 2em;
}

.video_section .container {
  width: 780px;
}

.video_section .vs_video {
  margin: 30px 0;
}

.video_section .vs_video a {
  display: inline-block;
  -webkit-transition: all .5s;
  transition: all .5s;
}

.video_section .vs_video a:hover {
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
}

.block_list {
  position: relative;
  padding: 6em 0;
}

.block_list.block_list_a {
  background: #fdf6c4;
  margin-top: 100px;
  padding: 3em 0 10em;
}

.block_list.block_list_a:before {
  content: '';
  position: absolute;
  top: -100px;
  left: 0;
  width: 100%;
  height: 212px;
  background: url(../images/wave_1.png) repeat-x center;
  background-image: -webkit-image-set(url(../images/wave_1.png) 1x, url(../images/wave_1@2x.png) 2x);
  background-image: image-set(url(../images/wave_1.png) 1x, url(../images/wave_1@2x.png) 2x);
  background-size: contain;
}

.block_list.block_list_c {
  background: #4671a7 url(../images/witness_bg.png) no-repeat left center;
  background-image: -webkit-image-set(url(../images/witness_bg.png) 1x, url(../images/witness_bg@2x.png) 2x);
  background-image: image-set(url(../images/witness_bg.png) 1x, url(../images/witness_bg@2x.png) 2x);
  background-size: 90% auto;
  padding: 3em 0 6em;
}

.block_list.block_list_c:before {
  content: '';
  position: absolute;
  top: -100px;
  left: 0;
  width: 100%;
  height: 212px;
  background: url(../images/wave_2.png) repeat-x center;
  background-image: -webkit-image-set(url(../images/wave_2.png) 1x, url(../images/wave_2@2x.png) 2x);
  background-image: image-set(url(../images/wave_2.png) 1x, url(../images/wave_2@2x.png) 2x);
  background-size: contain;
}

.block_list.block_list_c > li .bl_title .bl_title_b h3 {
  border-color: #fff;
  background: #fff6bf;
  color: #4671a7;
}

.block_list.block_list_c > li .bl_content {
  border-color: #fff;
  background: #4671a7;
  color: #fff;
}

.block_list.block_list_c > li .bl_content .bl_content_header,
.block_list.block_list_c > li .bl_content .bl_content_header:before,
.block_list.block_list_c > li .bl_content .bl_content_header:after,
.block_list.block_list_c > li .bl_content .bl_content_header span {
  border-color: #fff;
  background: #4671a7;
}

.block_list > li {
  position: relative;
  z-index: 2;
}

.block_list > li:not(:last-child) {
  margin-bottom: 5em;
}

.block_list > li .container {
  position: relative;
}

.block_list > li .bl_title .bl_title_b {
  position: relative;
  display: inline-block;
  left: -20px;
}

.block_list > li .bl_title .bl_title_b h3 {
  position: relative;
  z-index: 2;
  border: 3px solid #009db7;
  padding: 10px 4.5em 10px 1.5em;
  border-radius: 50em;
  background: #fee066;
  font-size: 1.36em;
  font-weight: bold;
  color: #009db7;
}

.block_list > li .bl_content {
  border-radius: 30px;
  border: 3px solid #009db7;
  text-align: center;
  background: #fff;
  margin-top: -40px;
  overflow: hidden;
}

.block_list > li .bl_content .bl_content_header {
  background: #5bebda;
  border-bottom: 3px solid #009db7;
  padding: 20px 30px;
  text-align: right;
  line-height: 0.8;
}

.block_list > li .bl_content .bl_content_header span {
  position: relative;
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid #009db7;
  background: #ffa38a;
}

.block_list > li .bl_content .bl_content_header:before, .block_list > li .bl_content .bl_content_header:after {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid #009db7;
  margin: 0 10px;
}

.block_list > li .bl_content .bl_content_header:before {
  background: #fdf6c4;
}

.block_list > li .bl_content .bl_content_header:after {
  background: #9ac9fb;
}

.block_list > li .bl_content .bl_content_body {
  padding: 40px 20px;
}

.block_list > li .bl_content .bl_content_in {
  display: inline-block;
  text-align: left;
}

.block_list > li .bl_content .ol_list_1 li {
  position: relative;
  margin: 12px 0;
  padding-left: 32px;
}

.block_list > li .bl_content .ol_list_1 li:before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 23px;
  height: 23px;
  background: #ff7a94;
  border-radius: 50%;
}

.block_list > li .bl_content .ol_list_1 li:after {
  content: '';
  position: absolute;
  left: 8px;
  top: 5px;
  width: 7px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.block_list > li .bl_content .ol_list_2 {
  width: 300px;
  max-width: 100%;
  margin: 0 auto;
}

.block_list > li .bl_content .ol_list_2 li {
  background: #baf0ee;
  text-align: center;
  margin-bottom: 10px;
  color: #3d4fb9;
  padding: 10px;
  border-radius: 50em;
}

.block_list > li .bl_content .ol_list_2 li:nth-child(even) {
  background: #f4d3e7;
}

.block_list > li .bl_content .feature {
  text-align: left;
}

.block_list > li .bl_content .feature .row {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.block_list > li .bl_content .feature h5 {
  color: #009db7;
  font-weight: bold;
}

.block_list > li .bl_content .feature p {
  text-align: justify;
}

.block_list > li.block__2 .bl_content .bl_content_body {
  padding: 60px 20px;
}

.block_list > li.block__2 .bl_content .feature {
  width: 550px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.block_list > li.block__4 .container {
  position: relative;
  z-index: 3;
}

.block_list > li.block__5 .container {
  width: 900px;
}

.block_list > li.block__5 .bl_content {
  text-align: left;
}

.block_list > li.block__5 .bl_content .bl_content_body {
  padding: 60px;
}

.block_list > li.block__5 .bl_content h5 {
  color: #fff6bf;
  font-weight: bold;
  font-size: 1.2em;
  margin-bottom: 10px;
}

.block_list > li.block__5 .bl_content p {
  line-height: 1.6;
  text-align: justify;
}

.block_list > li .deco {
  position: absolute;
  right: 40px;
  bottom: -20px;
}

.block_list > li .deco.deco_i03 {
  right: 20px;
  bottom: -50px;
}

.block_list > li .deco.deco_i04 {
  right: -20px;
  bottom: -50px;
}

.block_list > li .deco.deco_i05 {
  right: auto;
  left: 94%;
  bottom: -60px;
}

.property {
  font-size: 14px;
  color: #425875;
  margin-top: 30px;
}

.share_block {
  text-align: center;
  padding: 4em 20px;
  background: url(../images/share_bg.jpg) no-repeat center top/auto 150%;
  background-image: -webkit-image-set(url(../images/share_bg.jpg) 1x, url(../images/share_bg@2x.jpg) 2x);
  background-image: image-set(url(../images/share_bg.jpg) 1x, url(../images/share_bg@2x.jpg) 2x);
}

.share_block .share_block_box {
  position: relative;
  display: inline-block;
}

.share_block .share_block_box:before {
  content: '';
  position: absolute;
  width: 258px;
  height: 183px;
  background: url(../images/share_i01.png) no-repeat center/contain;
  background-image: -webkit-image-set(url(../images/share_i01.png) 1x, url(../images/share_i01@2x.png) 2x);
  background-image: image-set(url(../images/share_i01.png) 1x, url(../images/share_i01@2x.png) 2x);
  bottom: -10%;
  left: -12%;
}

.share_block .share_block_box:after {
  content: '';
  position: absolute;
  width: 165px;
  height: 43px;
  background: url(../images/share_i02.png) no-repeat center/contain;
  background-image: -webkit-image-set(url(../images/share_i02.png) 1x, url(../images/share_i02@2x.png) 2x);
  background-image: image-set(url(../images/share_i02.png) 1x, url(../images/share_i02@2x.png) 2x);
  top: 6%;
  right: -2%;
}

.share_block .share_block_box a {
  position: absolute;
  width: 75px;
  height: 75px;
  bottom: 25.5%;
}

.share_block .share_block_box .copyLink {
  left: 28.6%;
}

.share_block .share_block_box .fbShare {
  left: 44%;
}

.share_block .share_block_box .lineShare {
  left: 59.4%;
}

.wow.animated {
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
}

@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 10%, 0);
    transform: translate3d(0, 10%, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 10%, 0);
    transform: translate3d(0, 10%, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@media only screen and (max-width: 1120px) {
  .main_top {
    background-position: 53% center;
    height: 53.5vw;
    background-size: cover;
  }
}

@media only screen and (max-width: 1000px) {
  .n_header {
    width: 100%;
    top: 20px;
    left: 0;
    text-align: center;
  }
}

@media only screen and (max-width: 900px) {
  .block_list.block_list_c {
    background: #4671a7;
  }
  .block_list > li .deco.deco_i05 {
    left: auto;
    right: 20px;
    max-width: 50%;
  }
}

@media only screen and (max-width: 768px) {
  .all-content {
    font-size: 1.1em;
  }
  .n_header img {
    width: 92px;
    height: 30px;
  }
  .block_list {
    padding: 4em 0;
  }
  .block_list.block_list_c .col-3,
  .block_list.block_list_c .col-9 {
    width: 100%;
  }
  .block_list.block_list_c .col-3 {
    text-align: center;
    margin-bottom: 30px;
  }
  .block_list.block_list_c .col-3 img {
    max-width: 50%;
  }
  .block_list > li:not(:last-child) {
    margin-bottom: 2em;
  }
  .block_list > li .bl_title {
    text-align: center;
  }
  .block_list > li .bl_title .bl_title_b {
    left: 0px;
    display: block;
  }
  .block_list > li .bl_title .bl_title_b h3 {
    padding: 10px 30px;
    border-radius: 30px;
    border-width: 2px;
  }
  .block_list > li .bl_content {
    margin-top: 10px;
    border-width: 2px;
  }
  .block_list > li .bl_content .bl_content_header {
    padding: 15px 25px;
    border-width: 2px;
  }
  .block_list > li.block__5 .bl_content .bl_content_body {
    padding: 40px 20px;
  }
}

@media only screen and (max-width: 640px) {
  .form-title .i01 {
    display: none;
  }
  .share_block .share_block_box:before {
    width: 40vw;
    height: 28.5vw;
  }
  .share_block .share_block_box:after {
    width: 25.7vw;
    height: 6.7vw;
  }
  .share_block .share_block_box a {
    width: 11.7vw;
    height: 11.7vw;
  }
}

@media only screen and (max-width: 576px) {
  .all-content {
    font-size: 1.05em;
  }
  .n_header {
    top: 15px;
  }
  .main_top {
    height: 109.2vw;
    background: url(../images/banner-m.jpg) no-repeat center/cover;
    background-image: -webkit-image-set(url(../images/banner-m.jpg) 1x, url(../images/banner-m@2x.jpg) 2x);
    background-image: image-set(url(../images/banner-m.jpg) 1x, url(../images/banner-m@2x.jpg) 2x);
    min-height: 350px;
  }
  .block_list.block_list_a, .block_list.block_list_c {
    margin-top: 60px;
  }
  .block_list.block_list_a:before, .block_list.block_list_c:before {
    background-size: auto 40%;
  }
  .block_list > li .bl_content .ol_list_1 li {
    padding-left: 27px;
  }
  .block_list > li .bl_content .ol_list_1 li:before {
    width: 18px;
    height: 18px;
  }
  .block_list > li .bl_content .ol_list_1 li:after {
    left: 6px;
    top: 3px;
    width: 6px;
    height: 9px;
  }
  .block_list > li .bl_content .ol_list_1 li .d-block {
    display: inline-block;
  }
  .block_list > li.block__2 .bl_content .feature .col-3,
  .block_list > li.block__2 .bl_content .feature .col-9 {
    width: 100%;
  }
  .block_list > li.block__2 .bl_content .feature .col-3 {
    text-align: center;
    margin-bottom: 30px;
  }
  .block_list > li.block__2 .bl_content .feature .col-3 img {
    max-width: 30%;
  }
  .block_list > li.block__2 .bl_content .feature:not(:last-child) {
    margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: 1px dashed #ccc;
  }
  .block_list > li .deco {
    position: relative;
    display: block;
    margin: -20px auto 20px;
    right: auto !important;
    bottom: auto !important;
  }
  .property {
    font-size: 13px;
  }
  .property span {
    display: block;
  }
}

@media only screen and (max-width: 360px) {
  .case p {
    font-size: 1em;
  }
}
