/* 此份版單位請用rem */
/* 此份版單位請用rem */
/* 此份版單位請用rem */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  width: 100%;
  height: 100%;
  position: relative;
  font-family: 'Segoe UI', Arial, 'Microsoft YaHei', sans-serif;
}

body {
  background-color: #e3e3e3;
  -moz-user-select: none;
  user-select: none;
  touch-action: none;
  -webkit-user-select: none;
  -webkit-text-size-adjust: 100% !important;
  text-size-adjust: 100% !important;
  -moz-text-size-adjust: 100% !important;
}

div &::-webkit-scrollbar {
  display: none;
}

a {
  text-decoration: none;
}
input {
  font-size: 16px;
  font-family: 'Segoe UI', Arial, 'Microsoft YaHei', sans-serif;
  background-color: transparent;
  border: none;
  outline: none;
}

#app {
  width: 100%;
  height: 100%;
  position: relative;
  background-color: #f6f9ff;
  overflow: hidden;
}
.wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  overflow: hidden;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  background-color: #f6f9ff;
}
.full-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: min(100%, 560px);
  height: 100%;
  background-image: url('../img/bg.jpg');
  background-size: 100% auto;
  background-position: top center;
  background-repeat: no-repeat;
  background-color: #f7fbff;
  box-shadow: 0px 0px 4px 2px rgba(0, 0, 0, 0.15);
}
.main-content {
  display: flex;
  flex: 1;
  width: 100%;
}
.safe-content {
  display: flex;
  flex-direction: column;
  width: 7.5rem;
  height: 10.88rem;
  margin: auto;
}

.header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.27rem 0.54rem;
}
.header-lf,
.header-rt {
  display: flex;
  align-items: center;
  flex: 0.8;
}
.header-rt {
  justify-content: flex-end;
  margin-left: auto;
}
.header-center {
}
.header-menu {
  width: 0.33rem;
  margin-right: 0.26rem;
}
.header-menu__icon {
  display: block;
  width: 100%;
}
.header-brand {
  height: 0.6rem;
}
.header-brand__img {
  display: block;
  height: 100%;
}
.header-btn-group {
  display: flex;
  align-items: center;
  gap: 0.12rem;
  margin-right: 0.12rem;
  flex: 1;
}

.header-btn {
  height: 0.52rem;
  cursor: pointer;
}
.header-btn__icon {
  display: block;
  height: 100%;
}
.marquee-area {
  padding: 0.08rem;
  padding-top: 0;
  background: #ffffff;
}
.marquee-content {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0.04rem 0.12rem;
  background: #f5f5f5;
  border-radius: 1000px;
}
.marquee-icon {
  height: 0.24rem;
  margin-right: 0.1rem;
}
.marquee-icon__img {
  display: block;
  height: 100%;
}
.marquee-text {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  background-image: url('../img/marquee-text-bg.png');
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.marquee-text .text {
  font-size: 0.24rem;
  color: #fff;
  font-weight: bold;
  padding: 0 0.5rem;
  margin-left: 20%;
  margin-top: -0.02rem;
}
.marquee {
  overflow-x: hidden;
  font-size: 0.24rem;
  color: #929291;
  font-weight: bold;
  line-height: 1.5;
}
.slogan {
  display: flex;
  justify-content: center;
  width: 100%;
}
.slogan-img {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 75%;
}
.slogan-img img {
  width: 100%;
}
.main-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex: 1;
}
.main-btn .btn-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: 90%;
  height: 80%;
}
.main-btn .btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4%;
  width: 100%;
  height: calc((100% - 16%) / 3);
  border-radius: 0.16rem;
  cursor: pointer;
  background-color: #ffffff;
  box-shadow: 0px 0px 4px 2px rgba(132, 177, 206, 0.25);
}
.main-btn .btn-img {
  display: flex;
  align-items: center;
  width: 0.48rem;
}
.main-btn .btn-img img {
  display: block;
  width: 100%;
}
.main-btn .btn-text {
  font-size: 0.32rem;
  font-weight: 500;
  color: #0c4e78;
}
.btn-menu {
  display: none;
  position: absolute;
  bottom: 90%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 99;
  flex-shrink: 0;
  width: 80%;
  border-radius: 0.16rem;
  border: 1px solid #19b8ee;
  background-color: #ffffff;
  pointer-events: all;
}
.btn-menu.active {
  display: block;
}
.btn-menu::before {
  content: '';
  position: absolute;
  top: 99.5%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0.24rem 0.24rem 0 0.24rem;
  border-color: #ffffff transparent transparent transparent;
  filter: drop-shadow(0px 2px 0px #19b8ee);
}
.btn-menu .btn-group {
  width: 100%;
  padding: 6%;
}
.btn-menu .btn-lf,
.btn-rt {
  display: flex;
  align-items: center;
}
.btn-menu .btn-lf {
  width: 40%;
  justify-content: flex-end;
}
.btn-menu .btn-rt {
  width: 60%;
}
.btn-menu .btn {
  height: calc((100% - 32%) / 5);
  padding: 0.12rem;
  margin-bottom: 5%;
}
.btn-menu .btn:last-child {
  margin-bottom: 0;
}
.btn-menu .btn-img {
  height: 0.48rem;
}
.btn-menu .btn-text {
  margin-top: -2px;
  font-size: 0.28rem;
  color: #6d7c85;
}

.tabbar-area {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 99;
  min-width: 100%;
}
.tabbar {
  padding: 0.25rem;
  background: #ffffff;
  box-shadow: 0px -4px 4px 0px rgba(0, 0, 0, 0.15);
}
.tabbar-content {
  display: flex;
  flex-direction: column;
}
.tabbar-list {
  position: relative;
  display: flex;
  justify-content: space-around;
}
.tabbar-list .item-icon {
  height: 0.36rem;
}
.tabbar-list .item-icon img {
  display: block;
  height: 100%;
}
.tabbar-list .item-title {
  font-size: 0.24rem;
  color: #adb3c6;
  font-weight: bold;
  padding-top: 0.08rem;
  white-space: nowrap;
}
.tabbar-list__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  /* cursor: pointer; */
}

/* modal彈窗 */
.modal {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 98;
  overflow-x: hidden;
  overflow-y: hidden;
  width: 100%;
  height: 100%;
  max-width: 750px;
  background: rgba(0, 0, 0, 0.3);
  transition: opacity 0.15s linear;
  pointer-events: auto;
  -moz-user-select: none;
  user-select: none;
  touch-action: none;
  -webkit-user-select: none;
}
.modal.show {
  display: block;
}
.modal-dialog {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  width: 95%;
  height: 90%;
  max-height: 90%;
  background-image: url('../img/modal-bg.png');
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.modal-content.color-bg {
  border-radius: 10px;
  background-image: linear-gradient(
    #fcf4de 5%,
    #f8f6f5 10%,
    #f8f6f5 80%,
    #ffffff 100%
  );
}
.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 10;
  width: 6%;
  cursor: pointer;
}
.modal-close img {
  display: block;
  width: 100%;
}
.modal-header {
  display: flex;
  justify-content: center;
  padding-top: 0.48rem;
}
.modal-header img {
  display: block;
  width: 70%;
}
.modal-footer {
  display: flex;
  justify-content: center;
  margin-top: auto;
  padding: 0.4rem;
}
.modal-footer .btn-group {
  display: flex;
  gap: 5%;
  width: 80%;
}
.modal-footer .btn {
  flex: 1;
}
.modal-footer .btn img {
  display: block;
  width: 100%;
}
.modal-body {
  display: flex;
  justify-content: center;
  flex: 1;
  overflow-x: hidden;
  overflow-y: auto;
  padding-top: 0.16rem;
}
.modal-body .body-content {
  width: 80%;
}
.modal-body .title {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}
.modal-body .title img {
  display: block;
  max-width: 100%;
}
.modal-body .title .nobj-img {
  position: absolute;
  bottom: -30%;
  right: -10%;
  width: 25%;
}
.modal-body span {
  font-size: 0.28rem;
}
.modal-body p {
  padding: 0.24rem 0;
  font-size: 0.28rem;
  line-height: 1.5;
  color: #575757;
}
.modal-body .strong {
  color: #a73f13;
}
.modal-body ul {
  position: relative;
  padding: 0.24rem 0;
  margin-left: 0.4rem;
  font-size: 0.28rem;
  line-height: 1.5;
  color: #575757;
  list-style: decimal;
}
.modal-body .form-group {
  position: relative;
  width: 100%;
}
.modal-body .form-group .title {
  padding-bottom: 0.32rem;
}
.modal-body .form-group .title img {
  width: 30%;
}
.modal-body .form-img1 {
  position: absolute;
  top: 0;
  left: -8%;
  width: 20%;
}
.modal-body .form-img1 img {
  display: block;
  width: 100%;
}
.modal-body .form-img2 {
  position: absolute;
  bottom: -5%;
  right: -5%;
  width: 20%;
}
.modal-body .form-img2 img {
  display: block;
  width: 100%;
}
.modal-body .form-card-bg {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}
.modal-body .form-card-bg img {
  display: block;
  width: 40%;
}
.modal-body .form-card-bg::after {
  content: '';
  position: absolute;
  bottom: -100%;
  left: 50%;
  transform: translateX(-50%);
  width: 40%;
  height: 100%;
  background: #fff9ed;
}
.modal-body .form {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0.32rem;
  background: #fff9ed;
  border-radius: 10px;
  border: 1px solid #e1d7d0;
}
.modal-body .form-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-bottom: 0.24rem;
}
.modal-body .form-title {
  display: flex;
  align-items: center;
  flex: 1;
}
.modal-body .title-icon {
  display: block;
  width: 0.6rem;
}
.modal-body .title-text {
  text-align: right;
  font-size: 0.25rem;
  color: #2a0c0c;
  text-shadow: 0px 0px 3px #fff;
  white-space: nowrap;
}
.modal-body .form-input-group {
  width: 60%;
}
.modal-body .form-input {
  flex-grow: 0;
  width: 100%;
  padding: 0.08rem 0.16rem;
  font-size: 0.32rem;
  line-height: 1;
  border-radius: 1000px;
  border: 1px solid #d4d4d4;
  background: #fff;
  box-shadow: inset 2px 2px 3px rgba(141, 151, 166, 0.3);
}
.modal-body .form-input input {
  width: 100%;
  line-height: 1;
}
.modal-body .submit-btn {
  height: 0.8rem;
}
.modal-body .submit-btn img {
  display: block;
  height: 100%;
}
.modal-body .notice {
  display: flex;
  align-items: center;
  padding-top: 0.32rem;
  border-bottom: 0.06rem dotted #707070;
}
.modal-body .notice-icon {
  flex-shrink: 0;
  width: 0.84rem;
  margin-right: 0.16rem;
}
.modal-body .notice-icon img {
  display: block;
  width: 100%;
}
.modal-body .notice-text {
  font-size: 0.28rem;
  color: #575757;
  padding: 0;
}
.modal-body .notice-text span {
  color: #a73f13;
}
.modal-body .tips {
  margin-top: 0.28rem;
  padding: 0.28rem;
  border-radius: 10px;
  background-color: hsla(0, 0%, 100%, 0.6);
}
.modal-body .tips-text {
  font-size: 0.28rem;
  color: #575757;
  padding: 0;
}
.modal-body .tips-text span {
  color: #a73f13;
}
.modal-body .vip-dec {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  font-size: 0.32rem;
  color: #000;
}
.modal-body .vip-dec span {
  color: #cd3140;
}
.modal-body .vip-dec .dec-notice {
  display: flex;
  align-items: center;
}
.modal-body .vip-dec .dec-notice img {
  display: block;
  width: 0.8rem;
  margin-right: 0.16rem;
}
.modal-body .vip-dec .dec-notice p {
  text-align: left;
  padding: 0 0 0.16rem;
  color: #cd3140;
  border-bottom: 2px dashed #575757;
}
.modal-body .dot-list {
  list-style: disc;
}
.modal-body .pure-list {
  list-style: none;
}
.modal-body .point {
  padding: 0.08rem;
  border-radius: 1000px;
  background-color: #fff;
  box-shadow: 1px 1px 0px #967540;
}
.modal-body .vip-caption li {
  margin-bottom: 12px;
}
.modal-body .vip-caption span {
  display: inline-block;
  line-height: 1.5;
}
.modal-body .danger {
  color: #cd3140;
}
.modal-body .title-color {
  font-weight: bold;
  padding: 0;
  color: #967540;
}
.modal-body .table {
  margin: 0.24rem 0;
}
.modal-body .table .table-flex {
  display: flex;
  justify-content: center;
  align-items: center;
}
.modal-body .table th {
  font-size: 0.28rem;
  padding: 0.16rem;
}
.modal-body .table td {
  font-size: 0.28rem;
  padding: 0.16rem;
}
.modal-body .table.exclusive {
  overflow: hidden;
  border: 4px solid #fff;
  border-radius: 10px;
}
.modal-body .table.exclusive th {
  font-size: 0.28rem;
  background-color: #f4f3ef;
}
.modal-body .table.exclusive tr {
  border-bottom: 1px solid #ddd;
}
.modal-body .table.exclusive td {
  font-size: 0.28rem;
  vertical-align: baseline;
  background: #fafafa;
}
.modal-body .table.exclusive td:nth-of-type(odd) {
  background: #fff;
}
.modal-body .table.exclusive .title {
  display: flex;
  align-items: center;
}
.modal-body .table.exclusive .vip-icon {
  display: block;
  width: 0.8rem;
  margin-right: 0.16rem;
}
.modal-body .table.vip-table {
  margin: 0;
  width: 100%;
  border-collapse: collapse;
}
.modal-body .table.vip-table th {
  padding: 0;
  font-size: 0.2rem;
  background: #faf2ec;
  border: 1px solid #c8c8c8;
}
.modal-body .table.vip-table td {
  padding: 0.08rem 0;
  font-size: 0.2rem;
  text-align: center;
  border: 1px solid #000;
}
.modal-body .table.vip-table .table-icon {
  width: 100%;
  height: 50%;
}
.modal-body .table.vip-table .table-icon img {
  margin: auto;
  display: block;
  height: 50%;
}
.modal-body .vip-table-box {
  border: 1px solid #000;
  border-radius: 10px;
  overflow: hidden;
  margin: 0.24rem 0;
}
#modal3 .form-img1 {
  top: -7px;
  left: -10%;
  width: 23%;
}
#modal3 .form-img2 {
  width: 28%;
}
#modal4 .modal-header img {
  width: 90%;
}
#modal4 .modal-body .body-content {
  width: 95%;
}
.jc {
  width: 95%;
  height: 100%;
  margin: auto;
}
.jc-bg {
  background-image: url(../img/bg_jc.jpg);
}
.jc-bg .safe-content {
  padding: 0.6rem 0;
}
.jc-content {
  display: flex;
  flex-direction: column;
  height: 100%;
  border: 1px solid #fff;
  border-radius: 0.2rem;
}
.jc-top {
  padding: 0.12rem;
  background: #dce7fd;
  border-radius: 0.2rem 0.2rem 0 0;
}
.jc-top .jc-top-border {
  padding: 0.12rem;
  background: #fcfcfc;
  border-radius: 0.2rem;
  border: 1px solid #d4d4d4;
}
.jc-top .top-content {
  padding: 3%;
  background-color: #fff;
  border-radius: 0.2rem;
  box-shadow: 1px 1px 15px 4px rgba(51, 51, 102, 0.21) inset;
}
.jc-top .jc-brand {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
  padding-bottom: 15%;
}
.jc-top .brand-bg {
  position: absolute;
  bottom: -15%;
  display: block;
  width: 38%;
}
.jc-top .brand {
  position: absolute;
  top: -50%;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 18%;
}
.jc-top .brand img {
  position: relative;
  display: block;
  width: 100%;
}
.jc-top .jc-detail {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.jc-top .qrcode {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 1.24rem;
  aspect-ratio: 1 / 1;
  border-radius: 4px;
  box-shadow: 1px 1px 10px 2px #7f766a;
  background-color: #fff;
}
.jc-top .qrcode img {
  width: 90%;
}
.jc-top .detail {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 5%;
}
.jc-top .detail p {
  font-size: 0.28rem;
  color: #495674;
  font-weight: bold;
  margin-bottom: 0.08rem;
}
.jc-top .detail span {
  font-size: 0.2rem;
  color: #575757;
}
.jc-top .detail-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 0.16rem;
}
.jc-top .detail-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50%;
  min-height: 0.74rem;
  background-image: url('../img/btn-bg.png');
  background-position: center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
.jc-top .detail-btn span {
  font-size: 0.2rem;
  font-weight: bold;
  color: #fff;
  text-shadow: 1px 1px 1px solid #35608e;
}
.jc-bottom {
  flex: 1;
  width: 100%;
  overflow: hidden;
  background: #fff;
  border-radius: 0 0 0.2rem 0.2rem;
}
.jc-bottom .img-box {
  width: 100%;
  height: 100%;
  overflow-y: auto;
}
.jc-bottom img {
  display: block;
  width: 100%;
}
/* 電腦平板 */
@media (min-width: 480px) {
  .bottom-bar .swiper-slide {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: 0.36rem;
  }
  .bottom-bar .swiper-pagination {
    margin-top: 0.32rem;
  }
  .modal-body .form-item {
    width: 80%;
  }
  .modal-content {
    width: 90%;
  }
  .modal-body .submit-btn {
    height: 1rem;
  }
  #modal4 .modal-body .body-content {
    width: 90%;
  }
}
