@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&display=swap");

body {
  overflow-x: hidden;
}

body.fixed {
  overflow: hidden;
}

body * {
  font-family: "Noto Sans TC";
  font-size: 16px;
}

section {
  position: relative;
}

ul {
  margin: 0;
  padding: 0;
}

ul li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.pc {
  display: block !important;
}

@media screen and (max-width: 991px) {
  .pc {
    display: none !important;
  }
}

.mobile {
  display: none !important;
}

@media screen and (max-width: 991px) {
  .mobile {
    display: block !important;
  }
}

i[class*="icon-"] {
  width: 32px;
  height: 32px;
  display: inline-block;
  position: relative;
  content: "";
  background-position: center;
  background-repeat: no-repeat;
  -moz-background-size: contain;
  -o-background-size: contain;
  background-size: contain;
}

i[class*="icon-"].icon-arrow-up {
  width: 23px;
  height: 11px;
  background-image: url("../img/icon-arrow-up.svg");
  top: 2px;
}

input:focus {
  outline: none;
}

select {
  width: 100%;
  height: 36px;
  display: inline-block;
  padding: 0 60px 0 10px;
  font-size: 32px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: #000;
  margin-bottom: 3.5%;
  border: 1px solid #322c25;
  background: url(../img/icon-arrow-down.svg) no-repeat -webkit-calc(100% - 22px) 27px;
  background: url(../img/icon-arrow-down.svg) no-repeat -moz-calc(100% - 22px) 27px;
  background: url(../img/icon-arrow-down.svg) no-repeat calc(100% - 22px) 27px;
  background-color: rgba(255, 255, 255, 0.85);
  -moz-background-size: 18px;
  -o-background-size: 18px;
  background-size: 18px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
}

select::-ms-expand {
  display: none;
}

select:disabled {
  color: #727171;
  display: none;
}

select:invalid {
  color: #727171;
}

select:focus {
  outline: none;
}

body {
  background-color: #f1f1f1;
  font-size: 32px;
  color: #000;
}

section {
  width: 750px;
  margin: 0 auto;
  padding: 0px;
  background-color: #ffffff;
  position: relative;
}

section .container {
  max-width: 100% !important;
  padding: 0;
  margin: 0;
}

h1 {
  font-size: 1.125rem;
}

p.subtitle {
  font-size: 28px;
  text-align: center;
}

ul {
  margin-left: 1.5rem;
}

ul.number li {
  margin-bottom: 30px;
  list-style: decimal;
  font-size: 24px;
}

ul.dot li {
  margin-bottom: 30px;
  list-style: disc;
  font-size: 24px;
}

a {
  text-decoration: none;
  display: block;
}

a.btn-primary {
  width: 628px;
  margin: 30px auto;
  padding: 15px 0;
  font-size: 28px;
  background: #000000;
  color: #ffffff;
  text-align: center;
}

a.btn-col2 {
  width: 302px;
  margin: 30px 0;
  display: inline-block;
  padding: 15px 0;
  font-size: 28px;
  background: #000000;
  color: #ffffff;
  text-align: center;
}

a.btn-col2:first-child {
  margin-left: 60px;
  margin-right: 25px;
}

button {
  border: 0;
}

.chkbox {
  cursor: pointer;
  font-size: 24px;
  position: relative;
  padding-left: 42px;
}

.chkbox input {
  display: none;
}

.chkbox:after {
  position: absolute;
  width: 30px;
  height: 30px;
  top: 4px;
  left: 0;
  content: " ";
  color: #fff;
  display: inline-block;
  visibility: visible;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  border: 1px solid #ffffff;
  outline: 1px solid #000;
  z-index: 1;
}

.chkbox.active:before {
  position: absolute;
  width: 30px;
  height: 30px;
  top: 4px;
  left: 0px;
  content: "";
  background: url("../img/icon-check.png") no-repeat center/22px;
  background-color: #fff;
  display: inline-block;
  visibility: visible;
  color: #ffffff;
  z-index: 2;
}

header {
  width: 750px;
  margin: 0 auto;
  padding: 0;
  background: #000000;
  text-align: center;
}

header img {
  width: 100%;
  display: block;
  margin: 0 auto;
}
.bg {
  width: 750px;
  margin: 0 auto;
}
footer {
  width: 750px;
  margin: 0 auto;
  padding: 33px 0 36px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.5px;
  text-align: center;
  background-color: #fff;
  font-family: Arial, sans-serif;
}
#kv-section .btn_wrap a:hover,
#section-2 .btn_wrap a:hover,
#section-5 .btn_wrap a:hover {
  transform: scale(1.1);
}
#kv-section {
  background: url(../img/kv.jpg) center top no-repeat;
  height: 1200px;
  text-align: center;
  position: relative;
}
#kv-section .kv-logo {
  padding-top: 115px;
}
#kv-section .kv-logo > img {
  padding-bottom: 38px;
}
#kv-section h2 {
  font-size: 60px;
  font-weight: 500;
  color: #010101;
  letter-spacing: 1.5px;
  line-height: 0.9;
}
#kv-section p {
  margin: 0 auto;
  font-size: 36px;
  font-weight: 500;
  text-align: center;
  color: #dc535a;
  letter-spacing: 0.9px;
  text-shadow: 0px 1px 11px rgba(255, 255, 255, 0.52);
}
#kv-section .btn_wrap,
#section-2 .btn_wrap,
#section-5 .btn_wrap {
  position: absolute;
  bottom: 120px;
  width: 100%;
  text-align: center;
}
#kv-section .btn_wrap a,
#section-2 .btn_wrap a,
#section-5 .btn_wrap a {
  display: inline-block;
  margin: 0 10px;
}

#section-2 {
  background: url(../img/s2_bg.jpg) center top no-repeat;
  height: 1445px;
  text-align: center;
  position: relative;
}
#section-2 h2 {
  padding-top: 60px;
  margin-bottom: -7px;
}
#section-2 h3 {
  font-size: 60px;
  font-weight: 500;
  color: #161616;
  letter-spacing: 5px;
}
#section-2 h4 {
  margin-bottom: 33px;
  font-size: 36px;
  font-weight: 500;
  color: #dc535a;
  letter-spacing: 1px;
}
#section-2 h4 span {
  font-weight: 100;
  font-size: 36px;
}
#section-2 p {
  font-size: 24px;
  font-weight: 500;
  color: #333333;
  margin: 0 auto;
}
#section-2 p > img {
  margin-top: 33px;
}
#section-2 .good_pd {
  width: 301px;
  height: 645px;
  display: block;
  position: absolute;
  top: 563px;
  left: 100px;
}
#section-2 .good_pd_light span {
  display: block;
  width: 300px;
  height: 1000px;
  animation: light2 4.5s infinite linear;
  animation-delay: 1s;
  background: url(../img/light2.png) no-repeat center top;
  background-size: cover;
  opacity: 1;
}
#section-2 .good_pd_light {
  width: 301px;
  height: 645px;
  position: absolute;
  top: 0;
  left: 18px;
  -webkit-mask-image: url(../img/s2-prd.png);
}
@keyframes light2 {
  0% {
    opacity: 1;
    -webkit-transform: translatex(-400px);
    transform: translatex(-400px);
  }
  40% {
    -webkit-transform: translatex(600px);
    transform: translatex(600px);
  }
  100% {
    -webkit-transform: translatex(600px);
    transform: translatex(600px);
  }
}
#section-2 .good_item img {
  position: relative;
  z-index: 2;
  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;
}
#section-2 .good_item {
  width: 253px;
  height: 248px;
  background: url(../images/good_round1.png) no-repeat center;
  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;
}
#section-2 .item1 {
  position: absolute;
  top: 586px;
  left: 310px;
  -webkit-animation: 4s ease-in-out good_item2 infinite;
  animation: 4s ease-in-out good_item2 infinite;
}
#section-2 .item2 {
  position: absolute;
  top: 743px;
  left: 466px;
  -webkit-animation-delay: 300;
  animation-delay: 300;
  -webkit-animation: 2s ease-in-out good_item infinite;
  animation: 2s ease-in-out good_item infinite;
}
#section-2 .item3 {
  position: absolute;
  top: 939px;
  left: 396px;
  -webkit-animation: 1.8s ease-in-out good_item2 infinite;
  animation: 1.8s ease-in-out good_item2 infinite;
}
@keyframes good_item {
  0% {
  }
  40% {
    -webkit-transform: translateY(5px);
    transform: translateY(5px);
  }
  100% {
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }
}
@keyframes good_item2 {
  0% {
  }
  40% {
    -webkit-transform: translateY(-5px);
    transform: translateY(-5px);
  }
  100% {
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
  }
}
#section-3 {
  background: url(../img/s3_bg.jpg) center top no-repeat;
  height: 1184px;
  text-align: center;
  position: relative;
}

#section-3 h2 {
  margin-bottom: 40px;
  padding-top: 60px;
}
.swiper-pagination-bullet-active {
  background-color: #fff;
}
.swiper-pagination-bullet {
  background-color: #fff;
  width: 14px;
  height: 14px;
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 10px;
}
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 25px;
}

#section-4 {
  background: url(../img/s4_bg.jpg) center top no-repeat;
  height: 1364px;
  text-align: center;
  letter-spacing: 2px;
  position: relative;
}

#section-4 h3 {
  font-size: 30px;
  margin-top: 55px;
  font-weight: 700;
  margin-bottom: 20px;
}
#section-4 .icon {
  position: absolute;
  width: 100%;
  text-align: center;
}
#section-4 .s4-icon1 {
  top: 239px;
}
#section-4 .s4-icon2 {
  top: 682px;
}
#section-5 {
  height: 1534px;
  background: url(../img/s5_bg.jpg) center top no-repeat;
  text-align: center;
  letter-spacing: 2px;
}
#section-5 .btn_wrap {
  bottom: 240px;
}
#section-5 h2 {
  padding-top: 72px;
  margin: 0 auto;
}
#section-5 h3 {
  font-size: 60px;
  font-weight: 500;
  letter-spacing: 7px;
  color: #161616;
  margin: 0 auto;
}
#section-5 h4 {
  font-size: 36px;
  font-weight: 600;
  letter-spacing: 0px;
  color: #dc535a;
  padding-bottom: 36px;
  margin: 0 auto;
}
#section-5 h4 > span {
  font-size: 34px;
  font-weight: 100;
}
#section-5 p {
  font-size: 24px;
  font-weight: 400;
  text-align: center;
  color: #333333;
  letter-spacing: 0.72px;
}
#section-5 p > img {
  padding-top: 18px;
}
#section-6 {
  background: url(../img/s6_bg.jpg) center top no-repeat;
  height: 1121px;
  text-align: center;
  letter-spacing: 2px;
  position: relative;
}
#section-6 h2 {
  padding-top: 110px;
  font-size: 60px;
  font-weight: 500;
  color: #000000;
  letter-spacing: 3px;
}
#section-6 h4 > img {
}
#section-6 p {
  font-size: 28px;
  font-weight: 500;
  text-align: center;
  color: #3d3d3d;
  letter-spacing: 1.4px;
}
#section-6-2 {
  width: 750px;
  margin: 0 auto;
}
#section-6-2 > img {
  width: 100%;
}
#section-7 {
  background-color: #f6ebef;
  padding: 60px 70px 41px 70px;
  text-align: center;
}
#section-7 h2 {
  text-align: center;
  margin: 0 auto;
}
#section-7 h3 {
  font-size: 60px;
  font-weight: 500;
  color: #161616;
  letter-spacing: 3px;
  line-height: 1;
}
#section-7 h4 {
  font-size: 36px;
  font-weight: 600;
  color: #666666;
  letter-spacing: 3px;
}
#section-7 h5 {
  font-size: 36px;
  font-weight: 600;
  letter-spacing: 0px;
  color: #dc535a;
  padding-bottom: 40px;
  margin: 0 auto;
}
#section-7 h5 > span {
  font-size: 34px;
  font-weight: 100;
}
#section-7 p {
  font-size: 26px;
  font-weight: 400;
  color: #222222;
  letter-spacing: 4px;
  text-align: left;
  margin: 0 auto;
}
#section-7 h6 {
  padding-top: 31px;
  font-size: 20px;
  text-align: left;
  font-weight: 400;
}

.modal-dialog {
  max-width: 550px;
}

.modal-content {
  border: 10px solid rgba(255, 255, 255, 0.5);
}

.modal-body {
  position: relative;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  padding: 1rem;
  padding: 50px 30px 30px 30px;
}

.modal-body .close {
  background-color: transparent;
}

.modal-body .close span {
  font-size: 42px;
  color: #999;
  position: absolute;
  top: 10px;
  right: 10px;
}

.modal-body h2 {
  font-size: 30px;
  font-weight: 700;
  margin-bottom: 20px;
}

.modal-body p {
  font-size: 24px;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 1.3px;
  text-align: justify;
}

#thanks-section {
  margin: 0 auto;
  padding: 0;
  position: relative;
}

#thanks-section .logo {
  display: block;
  width: initial;
  position: absolute;
  top: 90px;
  left: 0;
  right: 0;
  margin: 0 auto;
}

#thanks-section h1 {
  width: 100%;
  font-size: 48px;
  font-weight: 500;
  font-stretch: normal;
  font-style: normal;
  letter-spacing: 1.8px;
  text-align: center;
  color: #242424;
  position: absolute;
  top: 184px;
  text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff;
}

#thanks-section img {
  display: block;
  width: 100%;
}

.progress {
  position: fixed;
  z-index: 1002;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: translateZ(0);
  background-color: #f1f1f1;
}

.progress__inner {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  padding-bottom: 20px;
  z-index: 0;
  text-align: center;
}

.progress__inner:after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: #fff;
  bottom: 0;
  left: 0;
}

.progress__bar {
  position: absolute;
  display: block;
  bottom: 0;
  z-index: 1;
  left: 0;
  width: 0%;
  height: 1px;
  background-color: #000;
}

.preloadWrp,
.preload {
  display: none;
}
