@charset "UTF-8";
/*思源黑體*/
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+TC:300,400,500,700&display=swap&subset=chinese-traditional");
/*思源襯線體*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@400;900&display=swap");
/*reset*/
html,
body {
  height: 100%;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
iframe,
button,
a {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  vertical-align: baseline;
  font: inherit;
  text-decoration: none;
  border: 0;
  letter-spacing: 0.7px;
}

input,
button,
textarea,
select,
optgroup,
option,
a {
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  outline: none;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  background: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  font-size: 1rem;
  line-height: 150%;
}

ol,
ul {
  list-style: none;
}

table {
  width: auto;
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  width: 100%;
  display: block;
}

/*reset end*/
.main-bn .video .before-play::after, .autoSize-169 .before-play::after, .progressBar .cir span, input[type=radio]:checked ~ label .icon::before {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/*定義rwd尺寸設定*/
/*最大行數設定*/
/*背景圖片設定*/
/*底圖區塊設定*/
/*區塊大小設定*/
/*箭頭設定*/
/*文字相關設定*/
.fs-xs {
  font-size: 0.75rem;
}

.fs-s {
  font-size: 0.875rem;
}

.fs-m {
  font-size: 1rem;
}

.fs-l {
  font-size: 1.125rem;
}

.fs-xl {
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .fs-xl {
    font-size: 1rem;
  }
}

.f-nowrap {
  white-space: nowrap;
}

/* color*/
.color-pink {
  color: #ff3366;
}

.color-gray {
  color: #707070;
}

.color-gray-500 {
  color: #535353;
}

.color-blue {
  color: #2b98ec;
}

/*排列*/
.tL {
  text-align: left;
}

.tR {
  text-align: right;
}

.tC {
  text-align: center;
}

.lineH-1-8 {
  line-height: 1.8;
}

.lineH-2 {
  line-height: 2;
}

/*粗細*/
.tB-300 {
  font-weight: 300;
}

.tB-400 {
  font-weight: 400;
}

.tB-500 {
  font-weight: 500;
}

.tB {
  font-weight: bold;
}

/*浮動設定*/
.fL {
  float: left;
}

.fR {
  float: right;
}

.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}

.clearfix {
  *zoom: 1;
  /*For IE 6&7 only*/
}

/*flex設定*/
.d-flex,
.d-flex-wrap {
  display: flex;
}

.d-flex-wrap {
  flex-wrap: wrap;
}

.flex-x-center {
  justify-content: center;
}

.flex-x-bet {
  justify-content: space-between;
}

.flex-y-start {
  align-items: flex-start;
}

.flex-y-center {
  align-items: center;
}

.flex-y-end {
  align-items: flex-end;
}

@media all and (max-width: 767px) {
  .m-d-flex-wrap {
    flex-wrap: wrap;
  }
}

@media all and (max-width: 767px) {
  .m-d-flex-direction {
    flex-direction: column;
  }
}

/*hr*/
hr {
  height: 1px;
  border: none;
  background-color: #d2d2d2;
  margin: 20px 0;
}

/*按鈕*/
.btnBx {
  display: flex;
  justify-content: center;
}
@media all and (max-width: 767px) {
  .btnBx {
    display: block;
  }
}
.btnBx a {
  display: block;
  min-width: 170px;
  background: linear-gradient(to right, #9e4c94, #8b4b96, #5789c4, #7cc7e0);
  color: #fff;
  font-size: 1.25rem;
  text-align: center;
  padding: 5px 20px;
  transition: 0.2s all ease-in-out;
  border-radius: 40px;
}
@media all and (max-width: 767px) {
  .btnBx a {
    font-size: 1.125rem;
  }
}
.btnBx a.reserve {
  position: relative;
  background: linear-gradient(to top, #9e4c94, #8b4b96, #5789c4, #7cc7e0);
}
.btnBx a.reserve::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  background-color: #fff;
  border-radius: 40px;
}
.btnBx a.reserve * {
  position: relative;
  z-index: 2;
  color: #707070;
}
.btnBx a + a {
  margin-left: 15px;
}
.btnBx a:hover {
  opacity: 0.8;
}
.btnBx a.pink {
  background: #ff3366;
}
.btnBx a.gray {
  background: #888;
}
.btnBx a.lightgray {
  background: #c9c9c9;
}
@media all and (max-width: 767px) {
  .btnBx a {
    min-width: auto;
    margin-bottom: 10px;
  }
  .btnBx a + a {
    margin-left: 0px;
  }
}

a.btn {
  padding: 5px 10px;
  color: #fff;
  background: #5887c3;
  display: block;
  border-radius: 5px;
  text-align: center;
}

/*a連結撐滿*/
.alink {
  position: absolute !important;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 5 !important;
}

/*寬度設定*/
.w-20 {
  width: 20% !important;
}
@media all and (max-width: 767px) {
  .w-20 {
    width: 100% !important;
  }
}

.w-40 {
  width: 40% !important;
}
@media all and (max-width: 767px) {
  .w-40 {
    width: 100% !important;
  }
}

.w-50 {
  width: 50% !important;
}
@media all and (max-width: 767px) {
  .w-50 {
    width: 100% !important;
  }
}

.w-70 {
  width: 70% !important;
}
@media all and (max-width: 767px) {
  .w-70 {
    width: 100% !important;
  }
}

.w-100 {
  width: 100% !important;
}

@media all and (max-width: 767px) {
  .m-w100 {
    width: 100%;
  }
}

.w-auto {
  width: auto !important;
}

.w-200x {
  max-width: 200px;
}
@media all and (max-width: 1440px) {
  .w-200x {
    max-width: 100% !important;
  }
}

.w-400x {
  max-width: 400px;
}
@media all and (max-width: 1440px) {
  .w-400x {
    max-width: 100% !important;
  }
}

/*大小網顯示設定*/
.web {
  display: block;
}
@media all and (max-width: 767px) {
  .web {
    display: none;
  }
}

.mobile {
  display: none;
}
@media all and (max-width: 767px) {
  .mobile {
    display: block;
  }
}

/*空間距設定*/
.space-s {
  height: 8px;
}

.space-m {
  height: 16px;
}

.space-lg {
  height: 24px;
}

.space-xl {
  height: 32px;
}

.space-xxl {
  height: 40px;
}

/*間距設定*/
.mb-s {
  margin-bottom: 8px;
}

.mb-m {
  margin-bottom: 16px;
}

.mb-lg {
  margin-bottom: 24px;
}

.mb-xl {
  margin-bottom: 32px;
}

@media all and (max-width: 767px) {
  .m-mb-m {
    margin-bottom: 16px;
  }
}

@media all and (max-width: 767px) {
  .m-mb-lg {
    margin-bottom: 24px;
  }
}

@media all and (max-width: 767px) {
  .m-mb-0 {
    margin-bottom: 0;
  }
}
.hover_common {
  transition: 0.2s all ease-in-out;
}
.hover_common:hover {
  opacity: 0.8;
}

/*Input設定*/
input[type=text],
input[type=password] {
  width: 100%;
  min-width: 60px;
  padding: 0 10px;
  height: 40px;
  line-height: 40px;
  border: 1px solid #d2d2d2;
  color: #000;
  font-weight: 400;
  border-radius: 5px;
}
@media all and (max-width: 767px) {
  input[type=text],
  input[type=password] {
    font-size: 1rem;
  }
}

input[type=text]:disabled,
input[type=password]:disabled {
  color: #999999;
  background: #f9f9f9;
  border: none;
}

input::-webkit-input-placeholder {
  color: #999999;
  font-size: 1rem;
  font-weight: 400;
}
@media all and (max-width: 767px) {
  input::-webkit-input-placeholder {
    font-size: 1rem;
  }
}

input:-moz-placeholder, input:-ms-input-placeholder, input::-moz-placeholder {
  color: #999999;
  font-size: 1rem;
  font-weight: 400;
}
@media all and (max-width: 767px) {
  input:-moz-placeholder, input:-ms-input-placeholder, input::-moz-placeholder {
    font-size: 1rem;
  }
}

/*select*/
select {
  width: 100%;
  min-width: 0;
  padding: 8px 35px 8px 10px;
  vertical-align: middle;
  color: #999999;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: url(../images/arrow-gray.svg) no-repeat right 15px center;
  border: none;
  background-size: 18px;
  font-size: 1rem;
  border: 1px solid #a0a0a0;
  font-weight: 400;
  background-color: #ffffff;
  border-radius: 5px;
}

@media all and (max-width: 767px) {
  .table-sy1 select {
    font-size: 1rem;
    padding: 5px 35px 5px 10px;
  }
}

select::-ms-expand {
  display: none;
}

select:disabled {
  color: #888;
  background-color: #e3e3e3;
  border: none;
}

/*checkbox*/
input[type=checkbox] {
  display: none;
}

input[type=checkbox] ~ label {
  display: inline-block;
  position: relative;
  padding-left: 30px;
  cursor: pointer;
}

input[type=checkbox] ~ label span {
  vertical-align: baseline;
}

input[type=checkbox] ~ label .icon {
  position: absolute;
  top: 4px;
  left: 0px;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 5px;
  background: #fff;
  background-size: 100%;
  border: solid 1px #a0a0a0;
  border-radius: 5px;
}

input[type=checkbox]:checked ~ label .icon::before {
  content: "";
  display: block;
  position: absolute;
  width: 20px;
  height: 20px;
  background: url(../images/check-mark.svg) no-repeat center center/contain;
}

/*radio*/
input[type=radio] {
  display: none;
}

input[type=radio] ~ label {
  display: inline-block;
  position: relative;
  padding-left: 30px;
  cursor: pointer;
}

input[type=radio] ~ label span {
  vertical-align: baseline;
}

input[type=radio] ~ label .icon {
  position: absolute;
  top: 3px;
  left: 0;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 5px;
  background: #fff;
  background-size: 100%;
  border: solid 1px #838182;
  border-radius: 50%;
}

input[type=radio]:checked ~ label .icon::before {
  content: "";
  display: block;
  position: absolute;
  width: 15px;
  height: 15px;
  background-color: #5887c3;
  border-radius: 50%;
}

#pageMenu {
  display: none;
}

/*小網選單*/
@media all and (max-width: 1200px) {
  #pageMenu {
    transition: 0.2s;
  }
  /* menu */
  #pageMenu {
    display: block;
    position: fixed;
    z-index: 9999;
    width: 60%;
    background: #fff;
    overflow-y: auto;
    top: 0;
    bottom: 0;
  }
  /* menu_清單 */
  #pageMenu ul {
    list-style: none;
    padding-left: 0px;
  }
  #pageMenu ul li {
    border-bottom: solid 1px #ececec;
  }
  #pageMenu ul a {
    display: block;
    height: 50px;
    line-height: 50px;
    color: inherit;
    text-decoration: none;
    padding-left: 20px;
    font-size: 1.125rem;
  }
  #pageMenu ul a.tips::after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 30px;
    height: 30px;
    background: url(../images/header_gift_icon.svg) no-repeat center center/19px auto;
  }
  #pageMenu ul a.sub {
    color: #ff3366;
    font-weight: bold;
  }
  #pageMenu ul a.new::after {
    content: " New";
    color: #f11319;
    font-size: 12px;
  }
  #pageMenu ul a.calendar {
    color: #ffae00;
    font-weight: bold;
  }
  #pageMenu .searchBx {
    background-color: #ececec;
    padding: 10px;
    display: flex;
  }
  #pageMenu .searchBx input {
    background-color: #fff;
    width: 100%;
    border-radius: 0;
    border: none;
  }
  #pageMenu .searchBx a {
    width: 40px;
    height: 40px;
    background: linear-gradient(to right, #9e4c94, #8b4b96, #5789c4, #7cc7e0);
    color: #fff;
    text-align: center;
    flex: 0 0 auto;
    line-height: 2.7;
    font-size: 0.875rem;
    position: relative;
  }
  #pageMenu .searchBx a img {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 25px;
    height: 25px;
    transform: translate(-50%, -50%);
  }
  #pageMenu li.info {
    display: flex;
    width: 100%;
    margin-top: 25px;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    border-bottom: none;
  }
  #pageMenu li.info a {
    width: 80%;
    padding-left: 0;
    text-align: center;
    border-bottom: none;
    border-radius: 30px;
  }
  #pageMenu li.info a + a {
    margin-left: 15px;
  }
  #pageMenu li.info .m-h-cart {
    width: 50px;
    height: 50px;
    position: relative;
    border: 1px solid #3d88b1;
    flex: 0 0 auto;
  }
  #pageMenu li.info .m-h-cart img {
    width: 30px;
    margin: 0 auto;
    padding-top: 5px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    padding-top: 0;
  }
  #pageMenu li.info .m-h-cart.point::before {
    content: "";
    display: block;
    position: absolute;
    right: 7px;
    top: 12px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #f24462;
    z-index: 2;
  }
  #pageMenu li.info .m-h-login {
    background: linear-gradient(to right, #369fce, #3468b2);
    color: #fff;
  }
  /* menu_按鈕 */
  .pageMenu-btn {
    display: block;
    position: absolute;
    right: 10px;
    top: 3px;
    width: 30px;
    height: 30px;
    background-size: 24px;
    outline: none;
    border: none;
  }
}
/*頁面基本設定*/
body {
  font: 16px/120% "Noto Sans TC", "微軟正黑體", "Helvetica Neue", sans-serif;
  font-weight: 400;
  letter-spacing: 0.7px;
  color: #000;
  background-color: #fff;
  line-height: 1.7;
}

.wrapper {
  position: relative;
  background-color: #fff;
}

.main {
  padding: 20px 0 0;
  position: relative;
}
.main.index {
  padding-bottom: 0;
}
@media all and (max-width: 1440px) {
  .main {
    padding: 15px 0 0;
  }
}
@media all and (max-width: 767px) {
  .main {
    padding: 10px 0 0;
  }
}

.in {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
}
@media all and (max-width: 767px) {
  .in {
    padding: 0 4vw;
  }
}
.in.repSet {
  max-width: 900px;
}

/*header*/
header {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 40;
  padding: 10px 0;
  background-color: #1b1b1b;
}
@media all and (max-width: 1200px) {
  header {
    padding: 0px 0;
  }
}

header .in {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  max-width: 100%;
}

.webviewMode {
  padding-top: 40px;
}

.header-back {
  padding: 0 4vw;
  background-color: #fff;
  position: fixed;
  z-index: 10;
  left: 0;
  right: 0;
  top: 0;
  box-shadow: 0 0 13px rgba(36, 49, 63, 0.2);
}
.header-back a {
  display: block;
  height: 100%;
  background: url(../images/prev.svg) no-repeat center left/30px auto;
  padding: 10px 10px 10px 30px;
}

.header-logo {
  position: relative;
  font-size: 1.875rem;
  font-weight: 300;
  color: #fff;
}
.header-logo span.web {
  display: inline-block;
}
@media all and (max-width: 1200px) {
  .header-logo span.web {
    display: none;
  }
}
@media all and (max-width: 1440px) {
  .header-logo {
    font-size: 1.5rem;
  }
}
@media all and (max-width: 1200px) {
  .header-logo {
    font-size: 1.5rem;
    letter-spacing: 1.5px;
    padding: 5px 0;
  }
}
.header-logo span.mobile {
  display: none;
}
@media all and (max-width: 1200px) {
  .header-logo span.mobile {
    display: inline-block;
  }
}
.header-logo img {
  width: 48px;
  margin-right: 5px;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  top: -2px;
}
@media all and (max-width: 1440px) {
  .header-logo img {
    width: 40px;
  }
}
@media all and (max-width: 767px) {
  .header-logo img {
    width: 40px;
  }
}

.header-list {
  display: flex;
}
.header-list > li {
  position: relative;
  font-size: 1.125rem;
  margin: 0px;
  color: #fff;
  height: 30px;
}
.header-list .txt {
  margin-right: 0px;
  transition: 0.3s all ease-in-out;
  padding: 25px 10px;
}
.header-list .txt:hover {
  color: #2b98ec;
}
.header-list .txt:hover.tips {
  background-image: url(../images/header_gift_icon_hover.svg);
}
.header-list .txt.tips {
  padding-right: 30px;
  background: url(../images/header_gift_icon.svg) no-repeat right 10px top 29px/contain;
  background-size: 20px auto;
}
.header-list .txt.sub {
  background-color: #ff3366;
  color: #fff;
  padding: 1px 10px 3px;
  border-radius: 3px;
  margin: 0 10px;
}
.header-list .txt.new {
  position: relative;
  padding-left: 40px;
}
.header-list .txt.new::before {
  content: "New";
  position: absolute;
  top: 25px;
  left: 10px;
  color: #f11319;
  font-size: 12px;
}
.header-list .txt.calendar {
  border: 1px solid #FFF100;
  color: #FFF100;
  padding: 1px 10px 3px;
  border-radius: 4px;
}
@media all and (max-width: 1200px) {
  .header-list li {
    display: none;
  }
  .header-list li.search {
    display: block;
    margin-right: 50px;
    top: -4px;
  }
  .header-list li.search img {
    width: 35px;
    height: 35px;
  }
}
.header-list .open {
  display: none;
}
.header-list .searchBx {
  position: fixed;
  top: 70px;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 40;
  display: none;
}
.header-list .searchBx .fm {
  padding: 25px 15px;
  background-color: #282828;
}
@media all and (max-width: 767px) {
  .header-list .searchBx .fm {
    padding: 15px;
  }
}
.header-list .searchBx .inner {
  max-width: 1000px;
  margin: 0 auto;
}
.header-list .searchBx .search-input {
  position: relative;
  margin-bottom: 15px;
}
.header-list .searchBx .search-input a {
  position: absolute;
  right: 15px;
  top: 12px;
  width: 25px;
  height: 25px;
  background: url(../images/search.svg) no-repeat center center/contain;
}
.header-list .searchBx .search-input a:hover {
  opacity: 0.8;
}
.header-list .searchBx input {
  border-radius: 5px;
  border: 1px solid #fff;
  background-color: transparent;
  height: 50px;
  line-height: 50px;
  font-size: 1.375rem;
  color: #fff;
}
@media all and (max-width: 767px) {
  .header-list .searchBx input {
    font-size: 1.25rem;
  }
}
.header-list .searchBx .keyword li {
  display: inline-block;
  margin-bottom: 15px;
  margin-right: 10px;
}
@media all and (max-width: 767px) {
  .header-list .searchBx .keyword li {
    margin-right: 5px;
  }
}
.header-list .searchBx .keyword li:hover a {
  background-color: #3e87bf;
}
.header-list .searchBx .keyword li a {
  background-color: #454545;
  color: #fff;
  padding: 3px 10px;
  border-radius: 5px;
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .header-list .searchBx .keyword li a {
    font-size: 1rem;
  }
}
.header-list .searchBx input::-moz-placeholder {
  color: #ffffff;
  font-size: 1.375rem;
}
.header-list .searchBx input:-ms-input-placeholder {
  color: #ffffff;
  font-size: 1.375rem;
}
.header-list .searchBx input:-moz-placeholder {
  color: #ffffff;
  font-size: 1.375rem;
}
.header-list .searchBx input::-webkit-input-placeholder {
  color: #ffffff;
  font-size: 1.375rem;
}
@media all and (max-width: 767px) {
  .header-list .searchBx input::-moz-placeholder {
    font-size: 1.25rem;
  }
  .header-list .searchBx input:-ms-input-placeholder {
    font-size: 1.25rem;
  }
  .header-list .searchBx input:-moz-placeholder {
    font-size: 1.25rem;
  }
  .header-list .searchBx input::-webkit-input-placeholder {
    font-size: 1.25rem;
  }
}

.searchCrol {
  z-index: 10;
}
.searchCrol .defult {
  display: none;
}
.searchCrol .open {
  display: block;
}
.searchCrol .searchBx {
  display: block;
}

.header-list-item {
  min-width: 144px;
  display: none;
  position: absolute;
  bottom: 0;
  transform: translateY(calc(100% + 10px));
  right: -5px;
  padding: 15px 15px;
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  border-radius: 6px;
  color: #000;
}
.header-list-item.cart {
  min-width: 240px;
}
.header-list-item li {
  margin-bottom: 10px;
}
.header-list-item li:first-child a {
  padding-top: 0;
}
.header-list-item li:last-child {
  margin-bottom: 0;
}
.header-list-item li a {
  text-align: center;
  white-space: nowrap;
  padding: 3px 20px;
  transition: 0.3s all ease-in-out;
}
.header-list-item li a:hover {
  color: #2b98ec;
}
.header-list-item p {
  font-size: 1rem;
}
.header-list-item p span {
  color: #2b98ec;
  margin: 0 5px;
}
.header-list-item .imgbx {
  width: 80px;
  margin: 0 auto;
  margin-bottom: 10px;
}
.header-list-item .imgbx + .btnBx a {
  width: auto;
  padding: 2px 20px 4px 20px;
  border-radius: 40px;
}
.header-list-item * {
  position: relative;
  z-index: 2;
}
.header-list-item .btnBx a {
  background: linear-gradient(to right, #369fce, #3468b2);
  font-size: 1.125rem;
  min-width: auto;
  padding: 3px 25px 6px 25px;
  margin-bottom: 10px;
}
.header-list-item .btnBx a {
  width: 100%;
  border-radius: 10px;
  padding: 2px 3px 4px 3px;
  margin-top: 15px;
}
.header-list-item .cart-class {
  width: 215px;
  padding: 15px 0;
  border-top: 1px solid #e8e8e8;
  border-bottom: 1px solid #e8e8e8;
  display: flex;
}
.header-list-item .cart-class:hover h5 {
  color: #5c9cce;
}
.header-list-item .cart-class + .cart-class {
  border-top: none;
}
.header-list-item .cart-class h4 {
  color: #ff3366;
  text-align: right;
  font-weight: bold;
}
.header-list-item .cart-class h5 {
  font-size: 0.81rem;
  line-height: 1.3;
  transition: 0.3s all ease-in-out;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
}
.header-list-item .cart-class .imgbx {
  flex: 0 0 auto;
  width: 105px;
  margin-right: 10px;
  margin-bottom: 0;
}
.header-list-item .cart-class .txt {
  margin-right: 0;
  padding: 0;
}
.header-list-item .cart-class .rwd-img {
  width: 100%;
  position: relative;
  padding-bottom: 56%;
}
.header-list-item .cart-class .rwd-img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.cart-class + .btnBx {
  margin-top: 20px;
}

.header-list-item::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 8px 8px 8px;
  border-color: transparent transparent #7cc7e0 transparent;
  position: absolute;
  right: 10px;
  top: 1px;
  transform: translateY(-100%);
}

.header-list-item::before {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% - 5px);
  height: calc(100% - 5px);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
}

.pageMenu-btn {
  display: none;
}
@media all and (max-width: 1200px) {
  .pageMenu-btn {
    display: block;
  }
}

.icon-sy {
  display: block;
  width: 28px;
  padding: 36px 20px;
  transition: 0.3s all ease-in-out;
  height: 10px;
  margin-top: -20px;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
.icon-sy img {
  width: 28px;
  height: 28px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.icon-sy:hover {
  opacity: 0.8;
}
.icon-sy.point {
  position: relative;
}
.icon-sy.point::before {
  content: "";
  display: block;
  position: absolute;
  right: 5px;
  top: 25px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #f24462;
  z-index: 2;
}

/*breadcrumb*/
.breadcrumb {
  position: relative;
  margin-bottom: 10px;
  font-size: 0.875rem;
}
@media all and (max-width: 1440px) {
  .breadcrumb {
    margin-bottom: 10px;
  }
}
@media all and (max-width: 767px) {
  .breadcrumb {
    margin-bottom: 5px;
  }
}
.breadcrumb li {
  display: inline-block;
  color: #3d88b1;
}
.breadcrumb li .b-point {
  width: 6px;
  height: 6px;
  vertical-align: middle;
  border-radius: 50%;
  background-color: #3d88b1;
  display: inline-block;
  margin-right: 8px;
}
.breadcrumb li + li::before {
  content: "/";
  margin: 0 5px;
}

/*標題設定*/
h2 {
  font-size: 1.875rem;
  margin-bottom: 30px;
}
h2.udL {
  position: relative;
  padding-bottom: 10px;
}
h2.udL::before {
  content: "";
  position: absolute;
  background-color: #3d88b1;
  width: 60PX;
  height: 2px;
  left: 0;
  bottom: 0;
}
h2.Tit {
  margin-bottom: 5px;
}
@media all and (max-width: 1440px) {
  h2 {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
}
@media all and (max-width: 767px) {
  h2 {
    font-size: 1.5rem;
    margin-bottom: 20px;
  }
}
h2 span {
  font-weight: bold;
  position: relative;
  padding-bottom: 10px;
}
@media all and (max-width: 767px) {
  h2 span {
    padding-bottom: 5px;
  }
}
h2 span::before {
  content: "";
  position: absolute;
  background-color: #3d88b1;
  width: 60px;
  height: 2px;
  left: 0;
  bottom: 0px;
}
@media all and (max-width: 767px) {
  h2 span::before {
    width: 50px;
    bottom: -4px;
  }
}
h2.classNm {
  position: relative;
  font-weight: bold;
}
h2.classNm::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: -10px;
  background-color: #5887c3;
  width: 60px;
  height: 2px;
}

h3 {
  font-size: 2rem;
  color: #434343;
  margin-bottom: 15px;
}
@media all and (max-width: 767px) {
  h3 {
    font-size: 1.75rem;
  }
}

h4.titsy1 {
  font-size: 1.125rem;
  color: #393939;
}

h5.titsy2 {
  font-weight: 500;
  font-size: 1rem;
  color: #393939;
  padding-left: 15px;
  position: relative;
}
h5.titsy2::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  background-color: #393939;
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

/*footer*/
footer {
  padding: 25px 0;
  position: relative;
  font-size: 0.875em;
  line-height: 1.5rem;
  color: #171717;
  z-index: 3;
}
@media all and (max-width: 1200px) {
  footer {
    color: #171717;
    font-size: 0.8rem;
  }
}
footer.hasfixed {
  padding-bottom: 130px;
}
@media all and (max-width: 1200px) {
  footer {
    padding: 15px 0;
  }
}
footer::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 5px;
  left: 0;
  top: -5px;
  background: linear-gradient(to right, #3b2c73, #793785, #ae4499, #2573b8, #5cc9e3);
}
footer a {
  color: #5887c3;
  transition: color 0.2s ease-in-out;
}
footer a:hover {
  color: #799fcf;
}
footer .in {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px 20px;
}
@media all and (max-width: 1200px) {
  footer .in {
    flex-direction: column;
    text-align: center;
  }
}
footer .l-bx {
  flex: 0 1 calc(50% - 20px);
}
footer .logo {
  font-size: 1.875rem;
  font-weight: 300;
  margin-bottom: 20px;
}
@media all and (max-width: 1200px) {
  footer .logo {
    font-size: 1.6rem;
    margin-bottom: 10px;
  }
}
@media all and (max-width: 767px) {
  footer .logo {
    font-size: 1.25rem;
    font-weight: 400;
  }
}
footer .logo img {
  width: 50px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 8px;
}
@media all and (max-width: 1200px) {
  footer .logo img {
    width: 40px;
  }
}
@media all and (max-width: 767px) {
  footer .logo img {
    width: 30px;
    position: relative;
    top: -3px;
  }
}
footer .icon {
  display: inline-block;
  width: 38px;
}
footer .mid-bx {
  flex: 1 1 auto;
}
footer .r-bx {
  text-align: right;
  position: relative;
}
footer .r-bx .icon-group {
  display: flex;
  justify-content: flex-end;
  gap: 0 12px;
  margin-left: auto;
  position: relative;
}
footer .r-bx a.icon + a:hover {
  color: #5c9bc2;
}
@media all and (max-width: 1680px) {
  footer .r-bx {
    text-align: right;
  }
}
footer .c-bx {
  width: 400px;
  display: flex;
  flex-wrap: wrap;
}
@media all and (max-width: 1680px) {
  footer .c-bx {
    width: 300px;
  }
}
@media all and (max-width: 1200px) {
  footer .c-bx {
    display: none;
  }
}
footer .c-bx li {
  width: 100%;
  position: relative;
  padding-left: 15px;
  line-height: 1.3;
  margin-bottom: 8px;
}
footer .c-bx li::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background-color: #5c9bc2;
  border-radius: 50%;
  margin-right: 8px;
  position: absolute;
  left: 0;
  top: 8px;
}
footer .c-bx li:hover a {
  color: #5c9bc2;
}
footer .c-bx a {
  transition: 0.3s all ease-in-out;
}

/*分頁樣式*/
.paginationArea {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 60px;
}
@media all and (max-width: 767px) {
  .paginationArea {
    margin-bottom: 40px;
  }
}
.paginationArea li {
  font-size: 1.25rem;
  color: #fff;
  position: relative;
  width: 35px;
  text-align: center;
  margin: 0 8px;
  transition: 0.2s all ease-in-out;
}
@media all and (max-width: 767px) {
  .paginationArea li {
    margin: 0 5px;
    width: 30px;
  }
}
.paginationArea li:hover {
  opacity: 0.8;
}
.paginationArea li::before {
  content: "";
  display: block;
  width: 35px;
  height: 35px;
  background-color: transparent;
  position: absolute;
  transition: 0.2s all ease-in-out;
  border-radius: 50%;
}
@media all and (max-width: 767px) {
  .paginationArea li::before {
    width: 30px;
    height: 30px;
  }
}
.paginationArea li.on a {
  color: #fff;
  background-color: transparent;
}
.paginationArea li.on a:hover {
  background-color: transparent;
}
.paginationArea li.on::before {
  background-color: #5887c3;
}
.paginationArea li a {
  position: relative;
  z-index: 1;
  color: #707070;
}
@media all and (max-width: 767px) {
  .paginationArea li a {
    top: -2px;
  }
}

.paginationArea .alprev a,
.paginationArea .prev a,
.paginationArea .alnext a,
.paginationArea .next a {
  vertical-align: middle;
  width: 30px;
  display: inline-block;
  position: relative;
}

.paginationArea .alprev a img,
.paginationArea .prev a img,
.paginationArea .alnext a img,
.paginationArea .next a img {
  width: 100%;
}

/*popupbox*/
.popupbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 40;
}
.popupbox .popup_con {
  position: fixed;
  top: 49%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 500px;
  width: calc(100% - 20px);
  z-index: 20;
  box-sizing: border-box;
  height: auto;
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  border-radius: 5px;
  position: relative;
}
.popupbox .popup_con::before {
  content: "";
  display: block;
  width: calc(100% - 6px);
  height: calc(100% - 6px);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
}
.popupbox .popup_con.middle {
  max-width: 650px;
}
.popupbox .popup_con.bigger {
  max-width: 850px;
}
.popupbox .popup_con > * {
  position: relative;
  z-index: 2;
}
.popupbox .close_btn {
  position: absolute;
  right: 0px;
  top: -40px;
  width: 35px;
  display: block;
  transition: 0.2s all ease-in-out;
  z-index: 3;
}
.popupbox .close_btn:hover {
  transform: rotate(90deg);
}
.popupbox h3 {
  background-color: #e5f2f2;
  color: #007d7d;
  font-size: 1.875rem;
  padding: 15px 10px;
  text-align: center;
  position: relative;
  top: 1px;
}
.popupbox .imgti {
  width: 95px;
  margin: 0 auto;
  margin-bottom: 8px;
}
.popupbox .qrcode {
  width: 300px;
  margin: 0 auto;
  margin-bottom: 8px;
}
.popupbox h4 {
  color: #000;
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 10px;
}
.popupbox .con {
  padding: 30px;
}
.popupbox .con .con-in {
  display: block;
  overflow-y: auto;
  margin-bottom: 0px;
}
@media all and (max-width: 767px) {
  .popupbox .con .con-in {
    margin-bottom: 20px;
  }
}
@media all and (max-width: 767px) {
  .popupbox .con {
    padding: 15px;
  }
}
.popupbox p {
  color: #313131;
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar {
  background-color: #c9c9c9;
  width: 6px;
}

.mCSB_scrollTools {
  opacity: 1;
}

.mCSB_scrollTools .mCSB_draggerContainer {
  background-color: #fff;
  width: 0px;
  left: 10px;
  border-radius: 5px;
}

.mCSB_scrollTools .mCSB_draggerRail {
  background-color: transparent;
}

.mCSB_inside > .mCSB_container {
  margin-right: 20px;
}

.mCSB_scrollTools .mCSB_dragger:hover {
  background-color: #c9c9c9;
}

/* 小網選單樣式 */
body {
  margin: 0;
  padding: 0;
  overflow-x: hidden !important;
}

.page {
  width: 100%;
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 2;
}

.page_cover {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  z-index: -2;
}

.openmenu {
  position: fixed;
}

.page.openmenu .page_cover {
  z-index: 1001;
}

.wrapper {
  width: 100%;
  min-height: 100vh;
  position: relative;
  box-sizing: border-box;
  background: #fff;
}

.pageMenu-btn .line {
  display: block;
  position: absolute;
  left: 0px;
  width: 30px;
  height: 3px;
  background-color: #fff;
  border-radius: 2px;
  transition: 0.2s;
}

.pageMenu-btn .line01 {
  top: 10px;
}

.pageMenu-btn .line02 {
  top: 20px;
}

.pageMenu-btn .line03 {
  top: 30px;
}

/* menu_按鈕_展開 */
.openmenu .pageMenu-btn .line01 {
  width: 30px;
  top: 14px;
  left: 2px;
  transform: rotate(-45deg);
}

.openmenu .pageMenu-btn {
  top: 10px;
}

.openmenu .pageMenu-btn .line02 {
  display: none;
}

.openmenu .pageMenu-btn .line03 {
  width: 30px;
  top: 14px;
  left: 2px;
  transform: rotate(45deg);
}

.show-left.openmenu {
  transform: translateX(60%);
}

.show-left ~ #pageMenu {
  top: 0;
  left: -60%;
}

.show-left.openmenu ~ #pageMenu {
  left: 0;
}

.show-right.openmenu {
  transform: translateX(-60%);
}

.show-right ~ #pageMenu {
  left: auto;
  right: -60%;
}

.show-right.openmenu ~ #pageMenu {
  right: 0;
}

.show-up ~ #pageMenu {
  top: -100%;
  left: 0;
  width: 100%;
  height: auto;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
}

.show-up.openmenu ~ #pageMenu {
  top: 0;
}

.show-up.openmenu {
  transform: translateX(0);
}

/*------------------------------------------*/
#pageMenu .hasSub {
  position: relative;
}
#pageMenu .hasSub button {
  position: absolute;
  top: 0;
  right: 0;
  width: 50px;
  height: 50px;
  background: url(../images/arrow.svg) center center no-repeat;
  background-size: auto 32px;
  cursor: pointer;
  outline: none;
  border: none;
  transition: 0.2s;
}
#pageMenu .hasSub.open > button {
  transform: scaleY(-1);
}

.bigArea {
  /*reset*/
  /*reset end*/
  /*Input*/
  /*select*/
  /*checkbox*/
  /*-----------------頁面-----------------*/
  /*header*/
  /*選單*/
  /*聯繫icon*/
  /*header 捲動*/
  /*footer*/
  /*swiper*/
  /*popup*/
  /*聯絡*/
  /*按鈕*/
  /*分享*/
}
.bigArea body,
.bigArea div,
.bigArea dl,
.bigArea dt,
.bigArea dd,
.bigArea ul,
.bigArea ol,
.bigArea li,
.bigArea h1,
.bigArea h2,
.bigArea h3,
.bigArea h4,
.bigArea h5,
.bigArea h6,
.bigArea pre,
.bigArea form,
.bigArea fieldset,
.bigArea input,
.bigArea textarea,
.bigArea p,
.bigArea blockquote,
.bigArea th,
.bigArea td,
.bigArea iframe,
.bigArea button,
.bigArea a {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  letter-spacing: 0.7px;
  vertical-align: baseline;
  text-decoration: none;
  box-sizing: border-box;
  line-height: 100%;
  font-weight: 300;
}
.bigArea body {
  color: #1b1b1b;
  background: #fff;
  font: 18px/100% "Noto Sans TC", "微軟正黑體", sans-serif;
}
.bigArea html,
.bigArea body {
  height: 100%;
}
.bigArea a {
  color: #1b1b1b;
  text-decoration: none;
}
.bigArea button {
  background: none;
}
.bigArea h1,
.bigArea h2,
.bigArea h3,
.bigArea h4,
.bigArea h5,
.bigArea h6 {
  font-weight: 300;
  font-size: 1rem;
}
.bigArea ol,
.bigArea ul {
  list-style: none;
}
.bigArea table {
  width: auto;
  border-collapse: collapse;
  border-spacing: 0;
}
.bigArea input,
.bigArea button,
.bigArea textarea,
.bigArea select,
.bigArea optgroup,
.bigArea option {
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  outline: none;
}
.bigArea input[type=text],
.bigArea input[type=password] {
  width: 100%;
  min-width: 100px;
  padding: 10px 10px;
  height: 40px;
  line-height: 32px;
  border: solid 1px #ddd;
}
.bigArea select {
  width: 100%;
  min-width: 60px;
  height: 40px;
  line-height: 32px;
  padding: 0 35px 0 10px;
  vertical-align: middle;
  color: #434343;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background-image: url(../images/icon_select.png);
  background-repeat: no-repeat;
  background-size: auto 8px;
  background-position: calc(100% - 10px) center;
  border: solid 1px #b5b5b5;
}
.bigArea select::-ms-expand {
  display: none;
}
.bigArea input[type=checkbox] {
  display: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  opacity: 0;
  line-height: 22px;
}
.bigArea input[type=checkbox] + label {
  line-height: 32px;
  cursor: pointer;
}
.bigArea input[type=checkbox] + label span {
  display: inline-block;
  width: 22px;
  height: 22px;
  margin: 0 10px 0 0;
  padding: 0;
  vertical-align: middle;
  cursor: pointer;
  background: url(../images/icon_check.png) left top no-repeat;
  background-size: 22px auto;
}
.bigArea input[type=checkbox]:checked + label span {
  background: url(../images/icon_check.png) left bottom no-repeat;
  background-size: 22px auto;
}
.bigArea input[type=checkbox] + label span.reverse {
  margin: 0 0 0 10px;
}
.bigArea textarea {
  width: 100%;
  min-height: 120px;
  padding: 10px 10px;
  border: solid 1px #ddd;
  overflow-y: auto;
  resize: none;
}
.bigArea .smallT {
  font-size: 14px;
}
.bigArea .bigT {
  font-size: 21px;
}
.bigArea .biggerT {
  font-size: 24px;
}
.bigArea .biggestT {
  font-size: 28px;
}
.bigArea .tL {
  text-align: left;
}
.bigArea .tR {
  text-align: right;
}
.bigArea .tC {
  text-align: center;
}
.bigArea .tB {
  font-weight: bold;
}
.bigArea .fL {
  float: left;
}
.bigArea .fR {
  float: right;
}
.bigArea .clr {
  clear: both;
}
.bigArea .web {
  display: block;
}
.bigArea .mobile {
  display: none;
}
.bigArea .tBig {
  font-size: 18px;
}
.bigArea .tBigger {
  font-size: 21px;
}
.bigArea .botM0 {
  margin-bottom: 0;
}
.bigArea .botM {
  margin-bottom: 15px;
}
.bigArea .botM2 {
  margin-bottom: 30px;
}
.bigArea .red {
  color: #bd1527;
}
.bigArea .bg_white {
  background: #fff;
}
.bigArea .wrapper {
  height: 100vh;
  min-height: 100vh;
  position: relative;
  padding-top: 100px;
}
.bigArea .pagesize {
  max-width: 1200px;
  margin: 0 auto;
}
.bigArea .container {
  padding: 40px 0;
  background: #f4f2f0;
}
.bigArea .contentInner {
  height: 100%;
  background: #fff;
  border-radius: 10px;
}
.bigArea .contentInner .innerBox {
  padding: 20px;
}
.bigArea .header {
  width: 100%;
  height: 100px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  border-bottom: solid 1px #e5e5e5;
  transition: 0.2s;
}
.bigArea .header {
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
}
.bigArea .headerIn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  height: 100px;
}
.bigArea .headerIn .logo a {
  display: block;
  width: 190px;
  height: 40px;
  background: url(../images/img_logo.png) left center no-repeat;
  background-size: 100% auto;
}
.bigArea .headerNav {
  display: flex;
  align-items: center;
}
.bigArea .headerMenu {
  display: inline-flex;
  align-items: center;
  margin-right: 30px;
}
.bigArea .headerMenu > li {
  padding: 0 10px;
  line-height: 100%;
  font-size: 20px;
  border-right: solid 1px #1b1b1b;
}
.bigArea .headerMenu > li:nth-last-child(1) {
  padding-right: 0;
  border-right: 0;
}
.bigArea .headerNav .contactLink {
  display: inline-flex;
}
.bigArea .contactLink a {
  display: inline-block;
  width: 40px;
  height: 40px;
  margin-right: 12px;
}
.bigArea .contactLink a:nth-last-child(1) {
  margin: 0;
}
.bigArea .contactLink a.link01 {
  background: url(../images/btn_link01_01.png) center no-repeat;
  background-size: 100%;
}
.bigArea .contactLink a.link02 {
  background: url(../images/btn_link01_02.png) center no-repeat;
  background-size: 100%;
}
.bigArea .contactLink a.link03 {
  background: url(../images/btn_link01_03.png) center no-repeat;
  background-size: 100%;
}
.bigArea .contactLink a.link04 {
  background: url(../images/btn_link01_04.png) center no-repeat;
  background-size: 100%;
}
.bigArea .header.sticky {
  height: 60px;
  background: rgba(255, 255, 255, 0.92);
}
.bigArea .header.sticky .headerIn {
  height: 60px;
}
.bigArea .header.sticky .headerIn .logo a {
  width: 140px;
  height: 30px;
}
.bigArea .header.sticky .contactLink a {
  width: 30px;
  height: 30px;
}
.bigArea .header.sticky .headerMenu > li {
  font-size: 18px;
}
.bigArea .footer {
  margin: 0;
  padding: 0;
  background: #fff;
}
.bigArea .footer_app {
  border-top: solid 1px #e5e5e5;
}
.bigArea .footer_app .pagesize {
  display: flex;
}
.bigArea .footer_app img {
  width: 100%;
}
.bigArea .footer_app .info01 {
  flex: 1 1 355px;
}
.bigArea .footer_app .info02 {
  flex: 1 1 525px;
}
.bigArea .footer_app .footer_app_link {
  flex: 1 1 160px;
}
.bigArea .footer .copyright {
  padding: 20px 10px;
  text-align: center;
  font-size: 15px;
  color: #fff;
  background: #404040;
}
.bigArea .swiper-button-prev,
.bigArea .swiper-button-next {
  outline: none;
}
.bigArea .popup_bg {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.5);
}
.bigArea .popup {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, calc(-50% - 30px));
  width: calc(100% - 20px);
  max-width: 720px;
  z-index: 10001;
}
.bigArea .popup_close {
  display: block;
  width: 21px;
  height: 21px;
  margin: 0 0 10px auto;
  background: url(../images/btn_popup_close.png) center no-repeat;
}
.bigArea .popup_box {
  width: 100%;
  padding: 60px 40px 40px;
  background: #fff;
  border-radius: 10px;
}
.bigArea .formbox {
  display: flex;
  margin-bottom: 20px;
  font-weight: 400;
}
.bigArea .formbox > p {
  flex: 1 0 5em;
  margin-right: 20px;
  line-height: 40px;
  font-size: 21px;
}
.bigArea .formbox .formInner {
  flex: 1 1 100%;
}
.bigArea .btnMain {
  text-align: center;
}
.bigArea .btnMain a {
  display: inline-block;
  width: 100%;
  max-width: 300px;
  line-height: 48px;
  font-size: 21px;
  text-align: center;
  color: #fff;
  background: #bd1527;
  border-radius: 4px;
}
.bigArea .reviewImg {
  margin-bottom: 16px;
}
.bigArea .reviewImg img {
  max-width: 100%;
}
.bigArea .reviewBox h4 {
  margin-bottom: 20px;
  font-size: 21px;
  font-weight: 400;
}
.bigArea .reviewBox p {
  font-size: 18px;
  line-height: 1.2em;
}
@media screen and (max-width: 1220px) {
  .bigArea .pagesize {
    padding: 0 20px;
  }
  .bigArea .headerIn {
    padding: 20px;
  }
}
@media screen and (max-width: 1100px) {
  .bigArea .headerIn .logo {
    flex: 0 1 180px;
    margin-right: 20px;
  }
  .bigArea .headerIn .logo a {
    width: 100%;
  }
  .bigArea .headerNav {
    flex: 1 0 auto;
    justify-content: flex-end;
  }
  .bigArea .headerMenu {
    margin-right: 20px;
  }
  .bigArea .contactLink a {
    width: 30px;
    height: 30px;
    margin-right: 8px;
  }
}
@media screen and (max-width: 1024px) {
  .bigArea .headerMenu li {
    padding: 0 6px;
    font-size: 18px;
  }
}
@media screen and (max-width: 800px) {
  .bigArea {
    /* page */
    /* header */
    /* footer */
    /*下載*/
    /*popup*/
    /*聯絡*/
    /*按鈕*/
    /* MMENU */
    /* 選單 */
    /*.mm-panel { padding: 60px 15px 0; }
    .mm-panel::after, .mm-panel::before { content: none; }
    .mm-panel_has-navbar { padding-top: 60px; }
    .mm-listitem { border-color: #c9c9c9; }
    .mm-panels>.mm-panel>.mm-listview { margin: 0 0 20px; }
    .mm-panels>.mm-panel>.mm-listview:first-child, .mm-panels>.mm-panel>.mm-navbar+.mm-listview { margin: 0; }
    .mm-listitem.mm-listitem_selected .mm-listitem__text,
    .mm-listitem.mm-listitem_opened > .mm-listitem__text ,
    .mm-listitem.mm-listitem_opened .mm-btn_next { background: #eee; border-bottom: solid 1px #c9c9c9; }
    .mm-listitem__text { padding: 15px 10px; }
    .mm-listitem__text::before { content: ""; display: inline-block; width: 6px; height: 6px; margin: -4px 5px 0 0; vertical-align: middle; background: #0382df; border-radius: 3px; }*/
  }
  .bigArea .web {
    display: none;
  }
  .bigArea .mobile {
    display: block;
  }
  .bigArea body {
    font-size: 16px;
  }
  .bigArea .wrapper {
    padding-top: 60px;
  }
  .bigArea .container {
    padding: 20px 0;
  }
  .bigArea .pagesize {
    padding: 0 10px;
  }
  .bigArea .wrapper {
    border-top: 0;
  }
  .bigArea .bigT {
    font-size: 18px;
  }
  .bigArea .biggerT {
    font-size: 21px;
  }
  .bigArea .biggestT {
    font-size: 24px;
  }
  .bigArea .header {
    height: 60px;
    position: fixed;
    top: 0;
    left: 0;
    padding: 0 10px;
    border-bottom: 0;
    z-index: 1000;
    transition: 0.2s;
    border-bottom: solid 1px #e5e5e5;
  }
  .bigArea .header .logo a {
    display: block;
    width: 150px;
    height: 60px;
    background: url(../images/img_logo.png) center no-repeat;
    background-size: auto 30px;
  }
  .bigArea .header .btnNav a {
    display: block;
    width: 60px;
    height: 60px;
    position: absolute;
    top: 0;
    right: 0;
    background: url(../images/btn_mmenu_01.png) center no-repeat;
    background-size: auto 20px;
  }
  .bigArea .footer {
    border-top: solid 1px #e5e5e5;
  }
  .bigArea .footer .contactLink {
    padding: 10px 0;
    text-align: center;
  }
  .bigArea .footer .contactLink a {
    width: 35px;
    height: 35px;
  }
  .bigArea .footer_app02 {
    text-align: center;
  }
  .bigArea .footer_app02 .title {
    margin-bottom: 10px;
    font-size: 30px;
    font-weight: 400;
  }
  .bigArea .footer_app02 .desc {
    margin-bottom: 10px;
    font-size: 18px;
    color: #dd0000;
  }
  .bigArea .footer_app02_link {
    display: flex;
  }
  .bigArea .footer_app02_link a {
    flex: 1 1 auto;
    height: 48px;
  }
  .bigArea .footer_app02_link .link01 {
    background: #191a1a url(../images/btn_link02_01.png) center no-repeat;
    background-size: auto 48px;
  }
  .bigArea .footer_app02_link .link02 {
    background: #898989 url(../images/btn_link02_02.png) center no-repeat;
    background-size: auto 48px;
  }
  .bigArea .footer_app02_link .link03 {
    background: #5078bc url(../images/btn_link02_03.png) center no-repeat;
    background-size: auto 48px;
  }
  .bigArea .popup_box {
    padding: 20px;
  }
  .bigArea .formbox {
    display: block;
  }
  .bigArea .formbox > p {
    font-size: 18px;
  }
  .bigArea .formbox .formInner {
    flex: 1 1 100%;
  }
  .bigArea .btnMain a {
    font-size: 18px;
  }
  .bigArea .mm-panel,
  .bigArea .mm-panels {
    background: #404040;
  }
  .bigArea .mm-menu a,
  .bigArea .mm-menu a:active,
  .bigArea .mm-menu a:hover,
  .bigArea .mm-menu a:link,
  .bigArea .mm-menu a:visited {
    color: #fff;
  }
  .bigArea .mm-listitem:after {
    background: #898989;
  }
  .bigArea .mm-panel {
    padding: 0;
  }
  .bigArea .mm-panels > .mm-panel > .mm-listview {
    margin: 0;
  }
  .bigArea .mm-listitem::after {
    left: 0;
  }
  .bigArea .mm-listitem__text {
    padding: 0 10px;
    line-height: 50px;
    text-align: center;
    font-size: 18px;
    font-weight: 400;
  }
}

.bigArea {
  /*area_banner*/
  /*介紹*/
  /*right*/
}
.bigArea .container {
  padding: 0;
}
.bigArea .area_banner {
  position: relative;
}
.bigArea .area_banner img {
  width: 100%;
}
.bigArea .area_banner .swiper-pagination {
  bottom: 40px;
  height: 6px;
}
.bigArea .area_banner .swiper-pagination .swiper-pagination-bullet {
  width: 48px;
  height: 6px;
  margin: 0 15px;
  vertical-align: top;
  background: #fff;
  border-radius: 0;
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.3);
}
.bigArea .bannerBox {
  position: relative;
}
.bigArea .bannerBox img {
  position: relative;
  transform: translate(0, 0);
}
.bigArea .bannerText {
  position: absolute;
  top: 260px;
  left: 0;
  width: 100%;
  text-align: center;
  color: #fff;
}
.bigArea .bannerText h2 {
  margin: 20px 0;
  font-size: 60px;
  line-height: 1.2em;
}
.bigArea .bannerText p {
  font-size: 30px;
  color: #ccc;
}
.bigArea .area_intro {
  padding: 40px 0;
}
.bigArea .introBox {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
}
.bigArea .introBox:nth-last-child(1) {
  margin: 0;
}
.bigArea .introBox .bn {
  flex: 1 1 500px;
  text-align: right;
}
.bigArea .introBox .bn img {
  max-width: 100%;
}
.bigArea .introBox.right .bn {
  text-align: left;
}
.bigArea .introBox .textbox {
  flex: 2 1 auto;
  margin-right: 20px;
}
.bigArea .introBox .textbox p {
  font-size: 21px;
  line-height: 36px;
}
.bigArea .introBox h2 {
  margin-bottom: 40px;
  font-size: 64px;
  line-height: 1em;
  font-weight: 500;
  color: #bd1527;
}
.bigArea .introBox h3 {
  margin-bottom: 32px;
  font-size: 24px;
  line-height: 1.2em;
}
.bigArea .introBox.right {
  flex-direction: row;
  justify-content: flex-start;
}
.bigArea .introBox.right .bn {
  margin-right: 20px;
}
.bigArea .introBox.right .textbox {
  margin: 0 0 0 60px;
}
@media screen and (max-width: 800px) {
  .bigArea {
    /*area_banner*/
    /*介紹*/
  }
  .bigArea .area_banner .swiper-pagination {
    bottom: 20px;
  }
  .bigArea .area_banner .swiper-pagination .swiper-pagination-bullet {
    width: 32px;
    margin: 0 10px;
  }
  .bigArea .introBox {
    display: block;
    margin-bottom: 40px;
    padding: 0;
  }
  .bigArea .introBox .bn,
  .bigArea .introBox.right .bn {
    width: calc(100% - 40px);
    max-width: 420px;
    margin: 0 auto 20px;
    text-align: center;
  }
  .bigArea .introBox .textbox,
  .bigArea .introBox.right .textbox {
    margin: 0;
    text-align: center;
  }
  .bigArea .introBox .textbox p {
    text-align: center;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
  }
  .bigArea .introBox h2 {
    margin-bottom: 20px;
    font-size: 32px;
  }
  .bigArea .introBox h3 {
    margin-bottom: 0;
    font-size: 16px;
    font-weight: 400;
  }
}
@media screen and (max-width: 500px) {
  .bigArea {
    /*介紹*/
  }
  .bigArea .introBox.right .bn {
    max-width: 320px;
  }
  .bigArea .introBox .textbox,
  .bigArea .introBox.right .textbox {
    margin: 0;
  }
  .bigArea .introBox h2 {
    text-align: center;
  }
}

.bigArea .area_intro {
  padding: 40px 60px;
  background-color: #f4f2f0;
}
@media (max-width: 1100px) {
  .bigArea .area_intro {
    padding: 40px 35px;
  }
}
@media all and (max-width: 1200px) {
  .bigArea .area_intro {
    padding: 40px 35px;
  }
}
@media all and (max-width: 767px) {
  .bigArea .area_intro {
    padding: 40px 0;
  }
}

.bigArea .introBox {
  margin-bottom: 30px;
}
@media all and (max-width: 1440px) {
  .bigArea .introBox.right .textbox {
    margin: 0 0 0 40px;
  }
}
@media all and (max-width: 1200px) {
  .bigArea .introBox.right .textbox {
    margin: 0;
  }
}
@media all and (max-width: 1200px) {
  .bigArea .introBox {
    margin-bottom: 50px;
    text-align: center;
  }
}

.bigArea .introBox .bn {
  flex: 0 0 350px;
  position: relative;
}
.bigArea .introBox .bn img {
  width: auto;
  margin: 0 auto;
}

.bigArea .introBox h2 {
  font-size: 50px;
}
@media all and (max-width: 1440px) {
  .bigArea .introBox h2 {
    font-size: 38px;
    margin-bottom: 20px;
  }
}
@media all and (max-width: 1200px) {
  .bigArea .introBox h2 {
    font-size: 32px;
    margin-bottom: 15px;
  }
}

@media (max-width: 1100px) {
  .bigArea .introBox .bn {
    flex: 0 0 250px;
  }
}
.bigArea .introBox .textbox .num {
  margin-bottom: 30px;
  font-family: "Roboto";
  font-size: 48px;
  font-weight: 700;
  color: #f5c60b;
}
@media all and (max-width: 1200px) {
  .bigArea .introBox .textbox .num {
    font-size: 32px;
    margin-bottom: 10px;
    text-align: center;
  }
}
.bigArea .redlight {
  color: #ed6a62;
}
.bigArea .green {
  color: #22ac38;
}
.bigArea .introBox h3 {
  line-height: 1.2em;
  font-weight: bold;
  color: #284c66;
  font-size: 28px;
}
@media all and (max-width: 1200px) {
  .bigArea .introBox h3 {
    font-size: 20px;
    margin-bottom: 10px;
  }
}
.bigArea .introBox .bn .icon {
  width: 40%;
  position: absolute;
  right: 70%;
  bottom: 85px;
  -webkit-filter: drop-shadow(15px 15px 15px rgba(0, 0, 0, 0.1));
  filter: drop-shadow(15px 15px 15px rgba(0, 0, 0, 0.1));
}
@media all and (max-width: 1200px) {
  .bigArea .introBox .bn .icon {
    max-width: 30%;
    right: 75%;
  }
}
.bigArea .introBox.right .bn .icon {
  right: auto;
  left: 70%;
}
@media all and (max-width: 1200px) {
  .bigArea .introBox.right .bn .icon {
    right: auto;
    left: 80%;
  }
}
.bigArea .introBox h2 span {
  position: relative;
}
.bigArea .introBox h2 span::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  bottom: 12px;
  left: calc(100% - 62px);
  width: 80px;
  height: 10px;
  background: #e7be07;
  border-radius: 10px;
}
@media all and (max-width: 1200px) {
  .bigArea .introBox h2 span::before {
    bottom: 5px;
  }
}
.bigArea .introBox.right h2 span::before {
  left: calc(100% - 60px);
}
.bigArea .introBox .textbox p span {
  font-weight: 500;
  color: #ee6f00;
}

/*行事曆*/
.calender_title {
  text-align: center;
  margin-bottom: 20px;
}
.calender_title .analysis_time {
  display: flex;
  align-items: center;
  justify-content: center;
}
.calender_title .analysis_time .month {
  font-size: 20px;
  font-weight: bold;
  color: #A4A4A4;
  line-height: 1.2em;
  margin: 0 20px;
}
.calender_title .analysis_time .month span {
  font-size: 30px;
  color: #000;
}
.calender_title .analysis_time .pre_arrow, .calender_title .analysis_time .nex_arrow {
  display: block;
  width: 40px;
  height: 40px;
}
.calender_title .analysis_time .pre_arrow a, .calender_title .analysis_time .nex_arrow a {
  display: block;
  height: 100%;
}
.calender_title .analysis_time .pre_arrow {
  background: url(../images/other-prev.png) no-repeat center/15px auto;
}
.calender_title .analysis_time .nex_arrow {
  background: url(../images/other-next.png) no-repeat center/15px auto;
}

.calender_main {
  background-color: #f3f3f3;
}

.cal_head {
  display: flex;
  position: sticky;
  top: 71px;
  z-index: 10;
  background-color: rgba(243, 243, 243, 0.9);
  box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.1);
}
.cal_head .item {
  flex: 1;
  text-align: center;
  line-height: 50px;
  font-size: 18px;
  text-transform: uppercase;
}
.cal_head .item:nth-last-child(2), .cal_head .item:last-child {
  color: #2A59B8;
}

.cal_body {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #A4A4A4;
  border-left: 1px solid #A4A4A4;
  margin-bottom: 30px;
}
.cal_body .item {
  width: 14.285%;
  padding: 10px 10px 0;
  border-right: 1px solid #A4A4A4;
  border-bottom: 1px solid #A4A4A4;
  min-height: 150px;
}
.cal_body .item.holiday {
  background-color: #E4E7ED;
}
.cal_body .item.holiday .day {
  color: #6274A5;
}
.cal_body .day {
  font-size: 1rem;
  line-height: 1em;
  margin-bottom: 10px;
}
.cal_body .day span {
  margin-left: 10px;
  display: none;
}
.cal_body ul {
  font-size: 1rem;
  line-height: 1.2em;
}
.cal_body li {
  position: relative;
  background-color: #ededed;
  border-radius: 6px;
  margin-bottom: 10px;
  padding: 5px 10px;
  transition: all 0.4s;
}
.cal_body li a {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.cal_body li.sty_1 {
  background-color: #E6DE6D;
  color: #8C8306;
}
.cal_body li.sty_1:hover {
  background-color: #8C8306;
  color: #fff;
}
.cal_body li.sty_2 {
  background-color: #AEC6DE;
  color: #2069A5;
}
.cal_body li.sty_2:hover {
  background-color: #2069A5;
  color: #fff;
}
.cal_body li.sty_3 {
  background-color: #DBCCE9;
  color: #6C3899;
}
.cal_body li.sty_3:hover {
  background-color: #6C3899;
  color: #fff;
}
.cal_body li.sty_4 {
  background-color: #EDBEBE;
  color: #813C3C;
}
.cal_body li.sty_4:hover {
  background-color: #813C3C;
  color: #fff;
}
.cal_body li:hover {
  box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.3);
}
.cal_body li.added::after {
  content: "已報名";
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  pointer-events: none;
}
.cal_body li.past {
  background-color: #aaa !important;
  color: #eee !important;
}
.cal_body li.vod::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 30px;
  height: 24px;
  margin-right: 5px;
  border-radius: 5px;
  background: #793785 url(../images/recording-icon.svg) no-repeat center center/auto 100%;
}
.cal_body li.past.vod:hover::after {
  content: "課程重播";
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  pointer-events: none;
}
.cal_body li.full::after {
  content: "已額滿";
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 6px;
}

@media all and (max-width: 767px) {
  .calender_main {
    margin: 0 -4vw;
  }
  .cal_head {
    display: none;
  }
  .cal_body {
    display: block;
    border: none;
    padding: 0 10px;
  }
  .cal_body .item {
    width: auto;
    padding: 0px;
    border: none;
    min-height: 0;
    border: 1px solid #ddd;
    margin-bottom: 20px;
  }
  .cal_body .item.noShow {
    display: none;
  }
  .cal_body .item.holiday .day {
    background-color: #0d68a6;
    color: #fff;
  }
  .cal_body .day {
    line-height: 1em;
    background-color: #444;
    color: #fff;
    padding: 10px;
    margin-bottom: 5px;
    text-align: center;
  }
  .cal_body .day::before {
    display: inline;
  }
  .cal_body .day.holiday ~ ul {
    border-color: #0d68a6;
  }
  .cal_body .day span {
    display: inline;
  }
  .cal_body ul {
    font-size: 16px;
    padding: 10px;
  }
  .cal_body li {
    background-color: transparent;
    background-position: center bottom 10px;
    margin-bottom: 5px;
    padding: 5px 10px;
    border-right: 1px solid #ebebeb;
  }
  .cal_body li.vod {
    display: flex;
    align-items: center;
  }
  .cal_body.m01 .day::before {
    content: "01/";
  }
  .cal_body.m02 .day::before {
    content: "02/";
  }
  .cal_body.m03 .day::before {
    content: "03/";
  }
  .cal_body.m04 .day::before {
    content: "04/";
  }
  .cal_body.m05 .day::before {
    content: "05/";
  }
  .cal_body.m06 .day::before {
    content: "06/";
  }
  .cal_body.m07 .day::before {
    content: "07/";
  }
  .cal_body.m08 .day::before {
    content: "08/";
  }
  .cal_body.m09 .day::before {
    content: "09/";
  }
  .cal_body.m10 .day::before {
    content: "10/";
  }
  .cal_body.m11 .day::before {
    content: "11/";
  }
  .cal_body.m12 .day::before {
    content: "12/";
  }
}
.colorBg-gradient {
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
}

.Gradient {
  padding: 15px 15px;
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  border-radius: 6px;
  position: relative;
}
.Gradient * {
  position: relative;
  z-index: 2;
}
.Gradient::before {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
}

.mx-w-min {
  max-width: 200px;
}
@media all and (max-width: 767px) {
  .mx-w-min {
    max-width: 100%;
  }
}

.tab {
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
}
@media all and (max-width: 767px) {
  .tab {
    width: calc(100% + 10px);
    margin-left: -5px;
    margin-bottom: 20px;
  }
}
.tab li:hover a {
  background-color: #f3f3f3;
}
@media all and (max-width: 767px) {
  .tab li {
    width: 100%;
  }
}
.tab a {
  display: block;
  width: 100%;
  padding: 8px 35px;
  border-top: 1px solid #aaa;
  border-bottom: 1px solid #aaa;
  border-left: 1px solid #aaa;
  text-align: center;
  font-size: 1.25rem;
  color: #707070;
  transition: 0.3s all ease-in-out;
  white-space: nowrap;
}
@media all and (max-width: 767px) {
  .tab a {
    padding: 5px;
    font-size: 1.125rem;
  }
}
.tab li:last-child a {
  border-right: 1px solid #aaa;
  border-radius: 0 40px 40px 0;
}
@media all and (max-width: 767px) {
  .tab li:last-child a {
    border-radius: 0 30px 30px 0;
  }
}
.tab li:first-child a {
  border-radius: 40px 0 0 40px;
}
@media all and (max-width: 767px) {
  .tab li:first-child a {
    border-radius: 30px 0 0 30px;
  }
}

li.on a {
  background-color: #aaa;
  color: #fff;
}
li.on a:hover {
  background-color: #919191;
}

.tab + .ms-con {
  margin-top: 45px;
}

.ms-con {
  padding: 20px 0;
  display: flex;
  justify-content: space-between;
  border-top: 1px solid #dcdcdc;
  position: relative;
  transition: 0.3s all ease-in-out;
}
@media all and (max-width: 767px) {
  .ms-con {
    padding: 15px 0;
    flex-wrap: wrap;
  }
}
.ms-con:hover {
  background-color: #f9f9f9;
}
.ms-con:hover h4 {
  color: #5887c3;
}
.ms-con h4 {
  padding-left: 18px;
  position: relative;
  color: #707070;
  font-size: 1.25rem;
  font-weight: bold;
  transition: 0.3s all ease-in-out;
}
.ms-con h4::before {
  content: "";
  display: block;
  position: absolute;
  left: 5px;
  top: 13px;
  width: 5px;
  height: 5px;
  background-color: #707070;
  border-radius: 50%;
}
@media all and (max-width: 767px) {
  .ms-con h4 {
    font-size: 1.125rem;
    margin-right: 0px;
  }
}
.ms-con .time {
  color: #959595;
}
@media all and (max-width: 767px) {
  .ms-con .time {
    width: 100%;
    text-align: right;
  }
}

.ms-con:last-child {
  border-bottom: 1px solid #dcdcdc;
}

.tab + .ms-con-inner {
  margin-top: 45px;
}
@media all and (max-width: 767px) {
  .tab + .ms-con-inner {
    margin-top: 15px;
  }
}

.ms-con-inner {
  color: #535353;
}
.ms-con-inner .ms-con {
  border: none;
}
.ms-con-inner .ms-con:hover {
  background-color: transparent;
}
.ms-con-inner .ms-con:hover h4 {
  color: #707070;
}

.edit-bx p {
  margin-bottom: 20px;
}

.listy-1 {
  margin-left: 30px;
}
.listy-1 li {
  text-indent: -2rem;
}

.order-item {
  position: relative;
  padding: 30px 30px 5px 30px;
  background-color: #eeeeee;
  color: #707070;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .order-item {
    padding: 15px 15px 5px 15px;
  }
}
.order-item:last-of-type {
  margin-bottom: 0;
}
.order-item .top {
  display: flex;
  position: relative;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .order-item .top {
    flex-direction: column;
    margin-bottom: 10px;
  }
}
@media all and (max-width: 767px) {
  .order-item .top .time {
    text-align: left;
    margin-bottom: 5px;
  }
}
.order-item .top .time::before {
  display: none;
}
.order-item .top .way::before {
  content: "付款方式";
}
@media all and (max-width: 767px) {
  .order-item .top .way::before {
    position: absolute;
    left: 0;
    top: 0;
    font-size: 1.125rem;
    color: #313131;
  }
}
.order-item .top .price {
  color: #ff3366;
}
.order-item .top .price::before {
  content: "實付金額";
}
@media all and (max-width: 767px) {
  .order-item .top .price::before {
    position: absolute;
    left: 0;
    top: 0;
    font-size: 1.125rem;
    color: #313131;
  }
}
.order-item .top p {
  font-size: 1.125rem;
  font-weight: 500;
}
@media all and (max-width: 767px) {
  .order-item .top p {
    text-align: right;
    position: relative;
    font-weight: 400;
  }
}
.order-item .top p::before {
  content: "";
  font-size: 0.875rem;
  margin-right: 15px;
  font-weight: 400;
  color: #707070;
}
.order-item .top p::after {
  content: "｜";
  margin: 0 10px;
}
@media all and (max-width: 767px) {
  .order-item .top p::after {
    display: none;
  }
}
.order-item .top p:last-of-type::after {
  display: none;
}
.order-item .state {
  position: absolute;
  right: 0px;
  background-color: #5887c3;
  color: #fff;
  padding: 2px 8px;
  border-radius: 5px;
}
.order-item .control {
  display: block;
  width: 100%;
  border-top: 1px solid #5887c3;
  color: #5887c3;
  text-align: center;
  padding-top: 8px;
  margin-top: 10px;
  margin-bottom: 5px;
}
.order-item .control::before {
  content: "查看詳細";
}
.order-item .control span {
  width: 8px;
  height: 8px;
  border-top: 2px solid #5887c3;
  border-right: 2px solid #5887c3;
  transform: rotate(135deg);
  display: inline-block;
  vertical-align: middle;
  position: relative;
  top: -5px;
  margin-left: 5px;
}
.order-item .control.open::before {
  content: "收合內容";
}
.order-item .control.open span {
  transform: rotate(-45deg);
  top: 0;
}
.order-item .inCon {
  height: 0;
  overflow: hidden;
  transition: 0.3s all ease-in-out;
}
.order-item .inCon.open {
  height: auto;
  border-top: 1px solid #9b9b9b;
  padding: 20px 0;
}
@media all and (max-width: 767px) {
  .order-item .inCon.open {
    padding: 0;
  }
}
.order-item h4 {
  font-size: 1.125rem;
  font-weight: bold;
  color: #535353;
  margin-bottom: 10px;
}

.support-item {
  padding: 30px;
  background-color: #eeeeee;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .support-item {
    padding: 15px;
  }
}
.support-item:last-of-type {
  margin-bottom: 0;
}
.support-item .top {
  display: flex;
  margin-bottom: 10px;
}
.support-item h4 {
  font-size: 1.125rem;
  font-weight: bold;
  color: #707070;
}
.support-item h4::before {
  content: "｜";
  margin: 0 10px;
}
@media all and (max-width: 767px) {
  .support-item h4::before {
    display: none;
  }
}
.support-item p {
  font-size: 1.125rem;
  color: #000;
}
.support-item p.time {
  font-size: 1rem;
  color: #707070;
}
.support-item_a {
  border-top: 1px solid #ccc;
  padding-top: 20px;
  margin-top: 20px;
}
@media all and (max-width: 767px) {
  .support-item_a {
    padding-top: 15px;
    margin-top: 15px;
  }
}
.support-item_a p {
  color: #5887c3;
}

.table-sy1 {
  width: 100%;
}
@media all and (max-width: 767px) {
  .table-sy1 {
    margin-bottom: 15px;
  }
}
.table-sy1 tr {
  border-bottom: 1px solid #9b9b9b;
}
@media all and (max-width: 767px) {
  .table-sy1 tr {
    border-bottom: 1px solid #9a9a9a;
    display: block;
    padding-bottom: 12px;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 thead {
    border: none;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
}
.table-sy1.btline-gradient {
  position: relative;
}
.table-sy1.btline-gradient tr:last-child {
  border-bottom: none;
}
.table-sy1.btline-gradient::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  background: linear-gradient(to left, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  width: 100%;
  height: 2px;
}
.table-sy1 thead tr {
  border-bottom: none;
}
.table-sy1 th {
  background-color: #c8d7ea;
  color: #5887c3;
  font-weight: 500;
  padding: 8px 5px;
  position: relative;
}
@media all and (max-width: 767px) {
  .table-sy1 th {
    display: none;
  }
}
.table-sy1 td {
  padding: 15px 5px;
  text-align: center;
  position: relative;
  justify-content: center;
}
@media all and (max-width: 767px) {
  .table-sy1 td.web {
    display: none;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 td {
    display: block;
    text-align: left;
    padding: 2px 0;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 td::before {
    content: attr(data-label);
    float: left;
    text-transform: uppercase;
    margin-right: 10px;
    color: #5887c3;
    width: 80px;
    font-weight: 400;
    flex: 0 0 auto;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 td:last-child {
    margin-bottom: 0;
  }
}
.table-sy1 td .function {
  display: block;
  width: 30px;
  margin: 0 auto;
  transition: 0.3s all ease-in-out;
}
.table-sy1 td .function:hover {
  opacity: 0.8;
}
.table-sy1 .imgbx {
  width: 130px;
  margin-right: 15px;
}
@media all and (max-width: 767px) {
  .table-sy1 .imgbx {
    width: 50%;
    margin-right: 0;
    margin-bottom: 10px;
  }
}
.table-sy1 .imgbx .img {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
}
.table-sy1 .imgbx .img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.table-sy1 .imgbx.app {
  width: 100px;
}
.table-sy1 .imgbx.app .img {
  padding-bottom: 100%;
}
.table-sy1 .ca-nm {
  display: flex;
  align-items: center;
}
@media all and (max-width: 767px) {
  .table-sy1 .ca-nm {
    flex-wrap: wrap;
    padding-top: 15px;
  }
}
.table-sy1 .ca-nm .txt {
  text-align: left;
}
@media all and (max-width: 767px) {
  .table-sy1 .ca-nm .txt {
    margin-bottom: 8px;
  }
}
.table-sy1 .ca-nm h5 {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  white-space: normal;
  margin-bottom: 5px;
}
@media all and (max-width: 767px) {
  .table-sy1 .ca-nm h5 {
    font-size: 1.125rem;
    margin-bottom: 5px;
  }
}
.table-sy1 .ca-nm p {
  font-size: 0.875rem;
}
.table-sy1 .ca-nm p span:first-child {
  margin-right: 10px;
}
.table-sy1 input[type=checkbox] ~ label .icon {
  top: 50%;
  transform: translateY(-70%);
}
@media all and (max-width: 767px) {
  .table-sy1 input[type=checkbox] ~ label .icon {
    transform: translateY(-50%);
    width: 25px;
    height: 25px;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 input[type=checkbox]:checked ~ label .icon::before {
    width: 25px;
    height: 25px;
  }
}
@media all and (max-width: 767px) {
  .table-sy1 input[type=checkbox] ~ label {
    padding-left: 35px;
    color: #5887c3;
  }
}

.btline-gradient.table-sy1 .ca-nm .txt {
  position: relative;
}
.btline-gradient.table-sy1 .ca-nm .txt .function {
  display: none;
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 .ca-nm .txt .function {
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 25px;
    opacity: 0.8;
  }
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 .ca-nm .txt {
    margin-bottom: 8px;
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 .ca-nm p {
    opacity: 0.7;
    font-size: 1rem;
  }
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 tr {
    margin-bottom: 20px;
    position: relative;
  }
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 td {
    margin-left: 40px;
    padding-top: 0;
  }
}
@media all and (max-width: 767px) {
  .btline-gradient.table-sy1 td.item-control {
    position: absolute;
    margin-left: 0;
    top: 80px;
    display: inline-block;
  }
  .btline-gradient.table-sy1 td.item-control::before {
    display: none;
  }
}

@media all and (max-width: 767px) {
  .order-fir {
    order: -2;
  }
}

@media all and (max-width: 767px) {
  .order-sec {
    order: -1;
  }
}

@media all and (max-width: 767px) {
  .m-block {
    display: block;
  }
}

@media all and (max-width: 767px) {
  .list-sy1 + .btnBx {
    margin-top: 15px;
  }
}

.list-sy1 {
  display: flex;
  flex-wrap: wrap;
}
@media all and (max-width: 767px) {
  .list-sy1 {
    margin-bottom: 0;
  }
}
.list-sy1 li {
  width: 49%;
  margin-right: 2%;
  position: relative;
  padding-left: 15px;
  display: flex;
}
@media all and (max-width: 767px) {
  .list-sy1 li {
    width: 100%;
    margin-right: 0;
    flex-direction: column;
    margin-bottom: 10px;
  }
}
.list-sy1 li h5 {
  margin-right: 15px;
}
.list-sy1 li:nth-child(2n) {
  margin-right: 0;
}
.list-sy1 li::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 10px;
  background-color: #535353;
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.list-sy2 {
  counter-reset: num;
}
.list-sy2 > li {
  display: block;
  margin-bottom: 8px;
  text-indent: -1.4rem;
  margin-left: 1.5rem;
}
.list-sy2 > li p {
  text-indent: 0;
  font-size: 1rem;
}
.list-sy2 > li::before {
  counter-increment: num;
  content: counter(num) ". ";
  font-weight: bold;
  color: #3d88b1;
}

.list-acolor {
  transition: 0.2s;
}
.list-acolor:hover {
  color: #3d88b1;
}

.list-bt-deco {
  position: relative;
  margin-bottom: 20px;
  padding-bottom: 20px;
}
@media all and (max-width: 767px) {
  .list-bt-deco {
    margin-bottom: 15px;
    padding-bottom: 15px;
  }
}
.list-bt-deco::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  border-bottom: 2px dotted #d9d9d9;
  width: 50%;
  height: 1px;
}
@media all and (max-width: 767px) {
  .list-bt-deco::before {
    width: 100%;
  }
}

.list-sy3 > li {
  position: relative;
  padding-left: 16px;
  text-indent: 0;
}
.list-sy3 > li::before {
  content: "";
  display: inline-block;
  background-color: #3d88b1;
  position: absolute;
  left: 0;
  top: 14px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.frame {
  padding: 20px 35px;
}
.frame.gray {
  background-color: #eee;
  color: #393939;
}
@media all and (max-width: 767px) {
  .frame {
    padding: 15px;
  }
}
.frame.radius {
  border-radius: 10px;
}
.frame hr {
  background-color: #626262;
  margin: 10px 0;
}
.frame.d-flex-c {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 300px;
}

.tabsy2 + .frame.gray {
  margin-top: 80px;
}

.frame.gray .ac-info {
  margin-top: -95px;
}

.ac-info {
  text-align: center;
}
.ac-info .imgbx {
  width: 105px;
  height: 105px;
  border-radius: 50%;
  position: relative;
  margin: 0 auto;
  margin-bottom: 15px;
}
.ac-info .imgbx .img {
  width: calc(100% - 6px);
  height: calc(100% - 6px);
  border-radius: 50%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  overflow: hidden;
}
.ac-info .imgbx .img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.ac-info .changeImg {
  position: absolute;
  width: 35px;
  height: 35px;
  background-color: #fff;
  border-radius: 50%;
  padding: 5px;
  right: -10px;
  bottom: 0px;
}
.ac-info h4 {
  color: #000;
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 5px;
}
.ac-info h4 .edit {
  display: inline-block;
  vertical-align: middle;
  width: 25px;
  height: 25px;
  position: relative;
  top: -2px;
}
.ac-info p {
  color: #707070;
  margin-bottom: 15px;
}
.ac-info .grayBtn {
  background-color: #bfbfbf;
  padding: 3px 25px 5px 25px;
  color: #fff;
  border-radius: 30px;
  transition: 0.3s all ease-in-out;
}
.ac-info .grayBtn:hover {
  background-color: #adacac;
}

.ac-edit {
  border-top: 1px solid #bfbfbf;
  padding-top: 30px;
}
.ac-edit .d-flex {
  justify-content: center;
}
@media all and (max-width: 767px) {
  .ac-edit .d-flex div + div {
    margin-top: 20px;
  }
}
@media all and (max-width: 767px) {
  .ac-edit {
    padding-top: 20px;
  }
}
.ac-edit .w-40 {
  margin-right: 40px;
}
@media all and (max-width: 767px) {
  .ac-edit .w-40 {
    margin-right: 0px;
  }
}
.ac-edit input {
  border-color: #a0a0a0;
}

.tit-psy {
  text-align: center;
  color: #535353;
  position: relative;
  font-weight: bold;
  /*&::before{
    content:"";
    display: block;
    position: absolute;
    left: 4px;
    top:10px;
    background-color: #535353;
    width: 6px;
    height: 6px;
    border-radius: 50%;
  }*/
}
.tit-psy.fs-l::before {
  top: 13px;
}

h4.tit-psy + p {
  padding-left: 18px;
}

.check-remi {
  max-width: 450px;
  margin: 0 auto;
}
.check-remi label {
  color: #707070;
}
.check-remi input[type=checkbox] ~ label {
  padding-left: 55px;
}
.check-remi input[type=checkbox] ~ label .icon {
  top: 2px;
  width: 40px;
  height: 20px;
  background: #b5b5b5;
  background-size: 100%;
  border-radius: 30px;
  border-color: transparent;
}
.check-remi input[type=checkbox] ~ label .icon::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  background-color: #888;
  border-radius: 50%;
  left: 2px;
  top: 1px;
  transition: 0.2s all ease-in-out;
}
.check-remi input[type=checkbox]:checked ~ label .icon {
  background-color: #86afe4;
}
.check-remi input[type=checkbox]:checked ~ label .icon::before {
  left: auto;
  right: 2px;
  background-color: #5887c3;
  background-image: none;
}

.login {
  max-width: 600px;
  margin: 0 auto;
  border-radius: 10px;
  position: relative;
  margin-top: 70px;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .login {
    margin-top: 50px;
  }
}
.login::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  background-color: #fff;
  border-radius: 8px;
}
.login * {
  position: relative;
  z-index: 2;
}
.login .imgbx {
  width: 110px;
  margin: 0 auto;
  margin-bottom: 15px;
  margin-top: -95px;
  z-index: 2;
  position: relative;
}
@media all and (max-width: 767px) {
  .login .imgbx {
    width: 80px;
    margin-top: -60px;
  }
}
.login h3 {
  font-size: 2rem;
  color: #535353;
  padding-bottom: 6px;
  border-bottom: 2px solid #3d88b1;
  display: inline-block;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .login h3 {
    font-size: 1.5rem;
  }
}
.login input {
  border-color: #a0a0a0;
}
.login .login-in {
  max-width: 400px;
  margin: 0 auto;
}
.login .set.d-flex {
  justify-content: space-between;
  margin-bottom: 30px;
}
.login .forgetPs {
  color: #959595;
  border-bottom: 1px solid #959595;
  padding-bottom: 1px;
}
.login input + input {
  margin-top: 16px;
}
.login .input {
  position: relative;
}
.login .input .verify {
  position: absolute;
  right: 5px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #3d88b1;
  font-size: 0.875rem;
  color: #fff;
  padding: 2px 10px;
  transition: 0.3s all ease-in-out;
}
.login .input .verify.disable {
  background-color: #bababa;
}
.login .input .verify:hover {
  background-color: #509dc7;
}
.login .b-not {
  font-size: 0.875rem;
  color: #959595;
}
.login .b-not a {
  border-bottom: 1px solid #3d88b1;
  padding-bottom: 1px;
  color: #3d88b1;
  transition: 0.3s all ease-in-out;
}
.login .b-not a:hover {
  opacity: 0.8;
}

body .input-warn {
  position: relative;
  font-size: 0.875rem;
  color: #f24563;
}
body .input-warn::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url(../images/input-warn.png) no-repeat center center/contain;
  margin-right: 5px;
  position: relative;
  top: 3px;
}

.state p {
  font-size: 1.125rem;
  margin-bottom: 3px;
}
.state p.mb-lg {
  margin-bottom: 24px;
}
@media all and (max-width: 767px) {
  .state p {
    font-size: 1rem;
  }
}
.state p + hr {
  margin-top: 50px;
}
@media all and (max-width: 767px) {
  .state p + hr {
    margin-top: 25px;
  }
}
.state h3 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 20px;
  color: #000;
}
@media all and (max-width: 767px) {
  .state h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
  }
}
.state h4 {
  text-indent: -2rem;
  margin-left: 2rem;
  font-size: 1.125rem;
  font-weight: bold;
  margin-bottom: 5px;
}
.state .list-sy2 > li,
.state .list-sy3 > li {
  font-size: 1.125rem;
}
@media all and (max-width: 767px) {
  .state .list-sy2 > li,
  .state .list-sy3 > li {
    font-size: 1rem;
    margin-bottom: 5px;
  }
}
.state .list-sy2 > li p {
  font-size: 1.125rem;
}
@media all and (max-width: 767px) {
  .state .list-sy2 > li p {
    font-size: 1rem;
  }
}

.contact-area .flex-1 {
  flex: 1;
}
.contact-area .flex-2 {
  flex: 2;
}
.contact-area_item {
  margin-right: 20px;
}
@media all and (max-width: 767px) {
  .contact-area_item {
    margin-right: 0px;
  }
}
.contact-area_item:last-child {
  margin-right: 0px;
}
.contact-area_item h4 {
  padding-left: 15px;
  position: relative;
  color: #393939;
  font-weight: bold;
  margin-bottom: 8px;
}
.contact-area_item h4::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #393939;
  display: block;
  position: absolute;
  left: 0;
  top: 12px;
}
.contact-area_item select {
  margin-right: 20px;
}
.contact-area_item select:last-child {
  margin-right: 0px;
}
.contact-area_item textarea {
  width: 100%;
}
.contact-area .list_img {
  display: flex;
  margin-bottom: 10px;
}
.contact-area .list_img .imgbox {
  background-color: #fff;
  width: 100px;
  height: 100px;
  overflow: hidden;
  position: relative;
  border: 2px solid #ddd;
  margin-right: 5px;
}
.contact-area .list_img .imgbox:hover {
  border-color: #9e4c94;
}
.contact-area .list_img .imgbox img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: auto;
}
.contact-area .list_img .imageUpload {
  background-color: #fff;
  width: 100px;
  height: 100px;
  border: 2px dashed #dcdee3;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 32px;
  user-select: none;
  color: #666;
  cursor: pointer;
}
.contact-area .list_img .imageUpload:hover {
  background-color: lightgray;
}
.contact-area .list_img .imageUpload div {
  font-size: 40px;
}

.progressBar {
  max-width: 400px;
  margin: 0 auto;
  margin-bottom: 30px;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.progressBar::before {
  content: "";
  display: block;
  position: absolute;
  top: 25px;
  left: 50%;
  width: 80%;
  height: 2px;
  background-color: #6471b4;
  transform: translateX(-50%);
}
.progressBar .cir {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  margin: 0 auto;
  margin-bottom: 10px;
  position: relative;
}
.progressBar .cir::before {
  content: "";
  display: block;
  position: absolute;
  width: calc(100% - 5px);
  height: calc(100% - 5px);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 50%;
}
.progressBar .cir span {
  position: relative;
  z-index: 2;
  position: absolute;
  color: #88cae2;
  font-size: 1.5rem;
}
.progressBar h5 {
  color: #a0a0a0;
}
.progressBar .on .cir {
  width: 55px;
  height: 55px;
  margin-bottom: 5px;
}
.progressBar .on .cir::before {
  background-color: transparent;
}
.progressBar .on .cir span {
  color: #fff;
  font-weight: bold;
}
.progressBar .on h5 {
  color: #000;
  font-size: 1.125rem;
  font-weight: 500;
}

.R-moneyli {
  display: flex;
  flex-wrap: wrap;
}
.R-moneyli .R-m-item {
  width: 16.8%;
  margin-right: 4%;
  min-width: 200px;
  margin-bottom: 5px;
}
.R-moneyli .R-m-item:nth-child(5n) {
  margin-right: 0;
}

p.total {
  color: #707070;
  position: relative;
}
@media all and (max-width: 767px) {
  p.total {
    width: 100%;
    text-align: center;
  }
}
p.total span {
  font-size: 2rem;
  color: #8d4b95;
  font-weight: bold;
  margin: 0 5px;
}

p.total + p.total::before {
  content: "｜";
  display: inline-block;
  margin: 0 5px;
}
@media all and (max-width: 767px) {
  p.total + p.total::before {
    content: "";
    margin: 0;
    position: absolute;
    height: 1px;
    width: 100%;
    left: 0;
    background-color: #d7d7d7;
  }
}

.video-js {
  width: 100%;
  height: 100%;
}

.class-vdBx {
  display: flex;
}
@media all and (max-width: 1200px) {
  .class-vdBx {
    flex-wrap: wrap;
  }
}
@media all and (max-width: 767px) {
  .class-vdBx {
    margin-right: -15px;
    margin-left: -15px;
    margin-bottom: 20px;
  }
}
.class-vdBx-video {
  width: 65%;
}
.class-vdBx-video.full {
  width: 100%;
}
@media all and (max-width: 1200px) {
  .class-vdBx-video.full {
    margin-bottom: 0;
  }
}
@media all and (max-width: 1200px) {
  .class-vdBx-video {
    width: 100%;
    margin-right: 0;
    margin-bottom: 20px;
  }
}
.class-vdBx-list {
  width: 35%;
  border-radius: 0;
  padding: 0;
  background-color: #e8e8e8;
  position: relative;
}
@media all and (max-width: 1200px) {
  .class-vdBx-list {
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  .class-vdBx-list {
    margin-top: -20px;
  }
}
.class-vdBx-list::before {
  border-radius: 0;
}
.class-vdBx-list h4 {
  width: 100%;
  position: relative;
  border-bottom: 2px solid #dddddd;
  position: relative;
  padding: 12px 15px;
  font-size: 1.125rem;
}
.class-vdBx-list h4 .time {
  position: absolute;
  right: 20px;
  top: 12px;
}
@media all and (max-width: 767px) {
  .class-vdBx-list h4 {
    font-size: 1.03rem;
  }
}
.class-vdBx-list h4 span {
  margin: 0 2px;
}

.autoSize-169 {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
}
.autoSize-169 img,
.autoSize-169 iframe,
.autoSize-169 video {
  position: absolute;
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
.autoSize-169 .before-play {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  cursor: pointer;
  z-index: 2;
}
.autoSize-169 .before-play::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 2;
}
.autoSize-169 .before-play::after {
  content: "";
  position: absolute;
  width: 100px;
  height: 100px;
  background: url(../images/play-index.svg) no-repeat center center/contain;
  z-index: 3;
}
@media all and (max-width: 767px) {
  .autoSize-169 .before-play::after {
    width: 60px;
    height: 60px;
  }
}

.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar {
  background-color: inherit;
}

.class-list {
  font-size: 1.125rem;
}
.class-list li {
  position: relative;
  padding: 10px 5px 8px 50px;
  border-bottom: 1px solid #c1c1c1;
  transition: 0.3s all ease-in-out;
}
@media all and (max-width: 1440px) {
  .class-list li {
    padding: 10px 5px 10px 50px;
  }
}
@media all and (max-width: 767px) {
  .class-list li {
    padding: 10px 5px 10px 47px;
  }
}
.class-list li.onplay {
  background-color: #dcedf8;
  border-radius: 0px;
  border: 1px solid #4688c8;
}
.class-list li::before {
  content: "";
  width: 24px;
  height: 24px;
  background: url(../images/class-arrow.png) no-repeat center center/contain;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 12px;
}
@media all and (max-width: 767px) {
  .class-list li::before {
    width: 20px;
    height: 20px;
  }
}
.class-list li:hover p {
  color: #3d88b1;
}
.class-list li span {
  color: #888;
  font-size: 0.875rem;
  white-space: nowrap;
  display: block;
}
@media all and (max-width: 767px) {
  .class-list li span {
    top: 0px;
    font-size: 0.93rem;
  }
}
.class-list li p {
  line-height: 1.4;
  transition: 0.2s all ease-in-out;
  letter-spacing: 0;
  font-size: 1.125rem;
}
@media all and (max-width: 1440px) {
  .class-list li p {
    font-size: 1rem;
  }
}
.class-list.lock li.try::before {
  content: "試看";
  background: #5887c3;
  color: #fff;
  width: auto;
  padding: 1px 5px;
  line-height: 1.4;
  border-radius: 30px;
  font-size: 0.9rem;
  left: 0px;
}
@media all and (max-width: 767px) {
  .class-list.lock li.try::before {
    padding: 2px 8px;
    line-height: 1.2;
    border-radius: 20px;
    font-size: 0.875rem;
  }
}
.class-list.lock li::before {
  content: "";
  width: 20px;
  height: 20px;
  background: url(../images/class-lock.svg) no-repeat center center/contain;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 10px;
}
@media all and (max-width: 767px) {
  .class-list.lock li::before {
    width: 16px;
    height: 16px;
    left: 12px;
  }
}

.class-vdBx-list {
  padding: 0;
  background-color: #e8e8e8;
  border-radius: 0px;
  position: relative;
}
.class-list-bx {
  padding: 10px 15px 10px 15px;
}
@media all and (max-width: 767px) {
  .class-list-bx {
    max-height: 300px;
    padding: 10px 10px 10px 10px;
    overflow-y: scroll;
  }
}

.class-info {
  display: flex;
  color: #626262;
}
@media all and (max-width: 767px) {
  .class-info {
    flex-wrap: wrap;
  }
}
.class-info .teacher {
  padding-left: 70px;
  position: relative;
  margin-right: 40px;
  width: 175px;
  flex: 0 0 auto;
}
.class-info .teacher .img {
  width: 60px;
  height: 60px;
  position: relative;
  border-radius: 50%;
  background-color: #999;
  position: absolute;
  left: 0;
  top: -4px;
  overflow: hidden;
}
.class-info .teacher .img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.class-info .student {
  border-left: 1px solid #626262;
  padding-left: 20px;
  margin-right: 30px;
  width: 240px;
  flex: 0 0 auto;
}
.class-info .bar {
  width: 100%;
}
.class-info .bar p {
  line-height: 1.4;
}
.class-info .bar .bar-line {
  width: 100%;
  height: 20px;
  border-radius: 20px;
  background-color: #e5e5e5;
}
.class-info .bar .bar-set {
  position: relative;
  height: 100%;
  background: linear-gradient(to right, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  border-radius: 20px 0 0 20px;
}
.class-info .bar .bar-set span {
  position: absolute;
  right: -20px;
  top: 0;
  transform: translateY(-130%);
  color: #ff3366;
  font-size: 1.125rem;
  font-weight: bold;
  display: block;
}
.class-info .bar .bar-set span::after {
  content: "%";
}

.icon-p {
  position: relative;
  padding-left: 35px;
}
.icon-p::before {
  content: "";
  width: 25px;
  height: 25px;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  top: 2px;
}
.icon-p.member {
  margin-bottom: 2px;
}
.icon-p.member::before {
  background-image: url(../images/class-member.png);
}
.icon-p.date::before {
  background-image: url(../images/class-date.png);
}

.in-banner {
  max-width: 1280px;
  margin: 0 auto;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .in-banner {
    margin-right: -15px;
    margin-left: -15px;
  }
}

.fixed-ad {
  position: fixed;
  z-index: 3;
  left: 0;
  bottom: 0;
  background: linear-gradient(to right, #3b2c73, #2573b8);
  padding: 20px 10px;
  color: #fff;
  font-size: 2rem;
  width: 100%;
  text-align: center;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.6);
  transition: 0.3s all ease-in-out;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
}
@media all and (max-width: 1440px) {
  .fixed-ad {
    flex-wrap: wrap;
  }
}
.fixed-ad .ic {
  width: 30px;
  vertical-align: middle;
  display: inline-block;
  margin-right: 10px;
  position: relative;
  top: 5px;
}
@media all and (max-width: 767px) {
  .fixed-ad .ic {
    width: 25px;
    top: 0;
  }
}
@media all and (max-width: 767px) {
  .fixed-ad .ic + p {
    display: inline-block;
  }
}
@media all and (max-width: 767px) {
  .fixed-ad {
    font-size: 1.25rem;
    padding: 15px 10px;
  }
}
.fixed-ad p {
  display: inline-block;
}
.fixed-ad p .b-txt {
  font-size: 2.5rem;
  font-weight: bold;
  margin: 0 5px;
}
@media all and (max-width: 767px) {
  .fixed-ad p .b-txt {
    font-size: 1.35rem;
  }
}
@media all and (max-width: 1440px) {
  .fixed-ad p {
    display: block;
    width: 100%;
  }
}
.fixed-ad p + a {
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .fixed-ad p + a {
    margin-left: 0;
  }
}
.fixed-ad a + a {
  margin-left: 10px;
}
.fixed-ad a {
  font-size: 1.5rem;
  padding: 6px 25px 8px;
  border-radius: 30px;
  font-weight: 500;
  display: inline-block;
  white-space: nowrap;
  transition: 0.3s all ease-in-out;
}
@media all and (max-width: 1440px) {
  .fixed-ad a {
    margin-top: 8px;
  }
}
@media all and (max-width: 767px) {
  .fixed-ad a {
    font-size: 1.125rem;
    margin-top: 5px;
    padding: 4px 25px 6px;
  }
}
.fixed-ad a.add {
  border: 1px solid #fff;
}
.fixed-ad a.add:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.fixed-ad a.buy {
  background-color: #ff3366;
}
.fixed-ad a.buy:hover {
  background-color: #ff527e;
}
.fixed-ad a.buy + a {
  margin-left: 10px;
}

.main-bn {
  margin-top: -30px;
  position: relative;
  overflow: hidden;
}
.main-bn .in {
  width: 100%;
  max-width: 1280px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media all and (max-width: 767px) {
  .main-bn .in {
    transform: translate(-50%, 0px);
    top: auto;
    bottom: 20px;
  }
}
.main-bn .video {
  max-width: 400px;
  margin-left: auto;
  margin-bottom: 30px;
  position: relative;
  cursor: pointer;
}
@media all and (max-width: 767px) {
  .main-bn .video {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10px;
    width: 285px;
  }
}
.main-bn .video .before-play {
  z-index: 2;
}
.main-bn .video .before-play::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: 2;
  width: 100%;
  height: 100%;
}
.main-bn .video .before-play::after {
  content: "";
  position: absolute;
  width: 45px;
  height: 45px;
  background: url(../images/play-index.svg) no-repeat center center/cover;
  z-index: 3;
}
.main-bn h3 {
  color: #fff;
  font-size: 2.8rem;
  font-weight: 500;
  margin-bottom: 150px;
  padding-right: 210px;
  position: relative;
  font-style: oblique;
  text-shadow: 0 0 15px rgba(0, 0, 0, 0.4);
}
.main-bn h3 span {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  border-bottom: 4px solid #ffda1e;
}
@media all and (max-width: 767px) {
  .main-bn h3 span {
    position: relative;
  }
}
@media all and (max-width: 1680px) {
  .main-bn h3 {
    margin-bottom: 50px;
  }
}
@media all and (max-width: 767px) {
  .main-bn h3 {
    font-size: 1.875rem;
    text-align: center;
    font-weight: 500;
    margin-bottom: 15px;
    padding-right: 0;
  }
}
.main-bn a {
  font-size: 1.875rem;
  padding: 5px 45px 8px 45px;
  border-radius: 30px;
  background-color: #ff3366;
  color: #fff;
  font-weight: bold;
  transition: 0.3s all ease-in-out;
}
@media all and (max-width: 767px) {
  .main-bn a {
    font-size: 1.5rem;
  }
}
.main-bn a:hover {
  background-color: #ff5680;
}

.mainBnSwiper {
  margin-top: -20px;
  margin-bottom: 20px;
}
.mainBnSwiper .video-frame {
  position: absolute;
  right: 3%;
  top: 50%;
  transform: translateY(-50%);
  width: 400px;
  height: 225px;
  margin-top: 0;
  background-color: #000;
}
@media all and (max-width: 1200px) {
  .mainBnSwiper .video-frame {
    width: 300px;
    height: 170px;
  }
}
@media all and (max-width: 767px) {
  .mainBnSwiper .video-frame {
    width: 100%;
    padding-bottom: 0;
    right: 0;
    height: auto;
    position: relative;
    top: auto;
    transform: none;
    display: none;
  }
}
.mainBnSwiper .video-frame img {
  opacity: 0.6;
}
@media all and (max-width: 1440px) {
  .mainBnSwiper {
    margin-top: -15px;
  }
}
@media all and (max-width: 767px) {
  .mainBnSwiper {
    margin-bottom: 25px;
  }
}
.mainBnSwiper .swiper-slide {
  position: relative;
  width: 100%;
  height: auto;
  padding-bottom: 28.64%;
}
@media all and (max-width: 1440px) {
  .mainBnSwiper .swiper-slide {
    height: auto;
    padding-bottom: 28.64%;
  }
}
@media all and (max-width: 767px) {
  .mainBnSwiper .swiper-slide {
    padding-bottom: 100%;
    height: auto;
  }
  .mainBnSwiper .swiper-slide.video {
    padding-bottom: 0;
  }
  .mainBnSwiper .swiper-slide.video .imgbx.mobile {
    padding-bottom: 100%;
  }
}
.mainBnSwiper .swiper-slide img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center bottom;
  object-position: center bottom 5%;
  transition: 0.2s all ease-in;
}
.mainBnSwiper .swiper-slide img.ani {
  opacity: 1;
}
@media all and (max-width: 767px) {
  .mainBnSwiper {
    margin-top: -10px;
  }
}

.videoBnSwiper {
  background: #eee url(../images/videoBnSwiper_bg.png) no-repeat;
  background-size: auto 380px;
  padding-bottom: 20px;
}
@media all and (max-width: 1200px) {
  .videoBnSwiper {
    background-position: top left -150px;
  }
}
@media all and (max-width: 767px) {
  .videoBnSwiper {
    background-image: none;
  }
  .videoBnSwiper .swiper-button-prev.arsy2,
  .videoBnSwiper .swiper-button-next.arsy2 {
    bottom: 10px;
  }
}
.videoBnSwiper .swiper-slide {
  opacity: 1;
}
.videoBnSwiper-block {
  display: flex;
  align-items: center;
}
@media all and (max-width: 767px) {
  .videoBnSwiper-block {
    display: block;
  }
}
.videoBnSwiper-pic {
  margin-right: 30px;
  width: 380px;
}
.videoBnSwiper-pic img {
  width: auto;
  max-width: 100%;
  max-height: 380px;
}
@media all and (max-width: 1200px) {
  .videoBnSwiper-pic {
    width: 280px;
  }
}
@media all and (max-width: 767px) {
  .videoBnSwiper-pic {
    display: none;
  }
}
.videoBnSwiper-title {
  flex: 1;
  margin-right: 30px;
  padding: 20px 0;
}
.videoBnSwiper-title h3 {
  font-size: 30px;
  font-weight: bold;
  position: relative;
  padding-bottom: 10px;
}
.videoBnSwiper-title h3::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 4px;
  border-radius: 3px;
  background-color: #2579bb;
}
.videoBnSwiper-title p {
  font-size: 24px;
  margin-bottom: 20px;
}
.videoBnSwiper-title a {
  display: inline-block;
  line-height: 40px;
  font-size: 20px;
  border-radius: 10px;
  color: #2579bb;
  border: 1px solid #2579bb;
  padding: 0 20px;
}
@media all and (max-width: 1200px) {
  .videoBnSwiper-title {
    margin-right: 0;
  }
  .videoBnSwiper-title h3 {
    font-size: 26px;
  }
  .videoBnSwiper-title p {
    font-size: 20px;
  }
}
.videoBnSwiper-video {
  margin: 20px 0;
  width: 460px;
}
@media all and (max-width: 1200px) {
  .videoBnSwiper-video {
    width: 300px;
  }
}
@media all and (max-width: 767px) {
  .videoBnSwiper-video {
    width: auto;
  }
}
.videoBnSwiper .video-frame {
  width: 100%;
  padding-bottom: 56.25%;
  position: relative;
  margin-top: 0;
  background-color: #000;
}
.videoBnSwiper .video-frame img {
  opacity: 0.6;
}
.videoBnSwiper .video-frame .videobx {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

.index .more.sw {
  top: 46px;
}
@media all and (max-width: 767px) {
  .index .more.sw {
    top: 24px;
  }
}

.more.sw {
  position: absolute;
  right: 0px;
  top: 34px;
  color: #626262;
  font-size: 1.25rem;
  border: 1px solid #c9c9c9;
  border-radius: 8px;
  padding: 2px 15px;
  transition: 0.3s all ease-in-out;
}
.more.sw:hover {
  background-color: #c9c9c9;
  color: #fff;
}
@media all and (max-width: 767px) {
  .more.sw {
    padding: 2px 12px;
    font-size: 1rem;
    top: 22px;
  }
}

@media all and (max-width: 767px) {
  .m-in {
    padding: 0 15px;
  }
}

@media all and (max-width: 767px) {
  .index .m-in {
    padding: 0 50px;
  }
}

.index h2.classNm {
  padding-right: 0;
}
@media all and (max-width: 767px) {
  .index h2.classNm::before {
    bottom: -5px;
  }
}
@media all and (max-width: 767px) {
  .index h2.classNm {
    font-size: 1.5rem;
  }
}
.index .block {
  padding: 40px 0;
  position: relative;
}
@media all and (max-width: 767px) {
  .index .block {
    padding: 20px 0;
  }
}
.index .block + .block {
  margin-top: -40px;
}
@media all and (max-width: 767px) {
  .index .block + .block {
    margin-top: -10px;
  }
}
.index .block.article + .block {
  margin-top: 0px;
}
.index h2 {
  margin-bottom: 32px;
}
.index h2.Tit {
  font-weight: bold;
  margin-bottom: 0;
}
.index h2.Tit + p {
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .index h2 {
    margin-bottom: 25px;
  }
}
.index .arr-tC {
  display: flex;
  justify-content: center;
  margin-top: 30px;
  margin-bottom: 10px;
}
@media all and (max-width: 767px) {
  .index .arr-tC {
    margin-top: 30px;
    margin-bottom: 20px;
  }
}
.index .arrow-bx {
  position: relative;
  width: 80px;
}
.index .arrow-bx .swiper-button-next::after,
.index .arrow-bx .swiper-button-prev::after {
  display: none;
}
.index .arrow-bx .swiper-button-next,
.index .arrow-bx .swiper-button-prev {
  width: 40px;
  height: 40px;
  right: 0;
  background: url(../images/arrowlight-gray.svg) no-repeat center center/contain;
}
.index .arrow-bx .swiper-button-next {
  transform: rotateZ(180deg);
}
.index .arrow-bx .swiper-button-prev {
  left: 0px;
  top: 2px;
}
.index .myclassli {
  padding: 0;
  width: 100%;
}
.index .myclassli .tag {
  display: flex;
  margin: 15px 0 5px 0;
}
@media all and (max-width: 767px) {
  .index .myclassli .tag {
    font-size: 0.875rem;
  }
}
.index .myclassli .tag span {
  color: #fff;
  background-color: #5887c3;
  border-radius: 30px;
  padding: 1px 8px;
}
.index .myclassli .tag span + span {
  margin-left: 5px;
}
.index .myclassli .price {
  color: #5887c3;
  font-size: 1.875rem;
  font-weight: bold;
  margin: 5px 0;
}
@media all and (max-width: 767px) {
  .index .myclassli .price {
    font-size: 1.5rem;
  }
}
.index .myclassli .price .subscribe {
  position: absolute;
  right: 0;
  top: 6px;
  color: #fff;
  background-color: #ab71cd;
  border-radius: 30px;
  font-size: 1rem;
  padding: 2px 15px;
  font-weight: 400;
}
.index .myclassli .price .subscribe.onebuy {
  background-color: #7770d1;
}
@media all and (max-width: 767px) {
  .index .myclassli .price .subscribe {
    position: relative;
    right: auto;
    display: block;
    font-size: 0.93rem;
    text-align: center;
    margin-bottom: 10px;
    width: 100%;
    max-width: 120px;
  }
}
.index .myclassli .info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #b5b5b5;
  border-bottom: 1px solid #b5b5b5;
  padding: 8px 0;
  margin-top: 5px;
}
.index .myclassli .info .teacher {
  color: #707070;
  font-weight: bold;
  font-size: 1.125rem;
}
@media all and (max-width: 1200px) {
  .index .myclassli .info .teacher {
    font-size: 1rem;
  }
}
.index .myclassli .info .time {
  color: #707070;
}
@media all and (max-width: 1200px) {
  .index .myclassli .info .time {
    font-size: 1rem;
  }
}
.index .myclassli .info .time::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  background: url(../images/time.svg) no-repeat center center/contain;
  position: relative;
  top: 4px;
  margin-right: 5px;
}
@media all and (max-width: 1200px) {
  .index .myclassli .info .time::before {
    width: 18px;
    height: 18px;
    top: 3px;
  }
}
.index .myclassli:hover {
  background: transparent;
}

.index .block.first {
  padding-top: 0px;
}
.index .block.first .more.sw {
  top: 0;
}
@media all and (max-width: 767px) {
  .index .block.first .more.sw {
    top: 15px;
  }
}
@media all and (max-width: 767px) {
  .index .block.first {
    padding-top: 10px;
  }
}

.blue.block .arr-tC {
  margin-top: 15px;
}

.bestVideoSwiper {
  margin-top: 32px;
  position: relative;
  transition: 0.8s all ease-in-out;
}
.bestVideoSwiper.ani {
  top: 0;
  opacity: 1;
}
@media all and (max-width: 767px) {
  .bestVideoSwiper {
    margin-top: 20px;
    overflow: hidden !important;
  }
}
.bestVideoSwiper .swiper-slide {
  border-radius: 10px;
  overflow: hidden;
  background-color: #fff;
  text-align: center;
  opacity: 0.5;
  width: calc((100% - 60px) / 3);
  margin-right: 30px;
}
@media all and (max-width: 767px) {
  .bestVideoSwiper .swiper-slide {
    width: calc(100vw - 30px);
    margin-right: 30px;
  }
}
.bestVideoSwiper .swiper-slide:hover img {
  transform: scale(1.1);
}
.bestVideoSwiper .swiper-slide.swiper-slide-active {
  opacity: 1;
}
.bestVideoSwiper .swiper-slide.swiper-slide-active img {
  opacity: 0.5;
}
.bestVideoSwiper h4 {
  font-size: 1.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  box-sizing: border-box;
  margin-top: 20px;
  padding: 0 20px;
}
@media all and (max-width: 767px) {
  .bestVideoSwiper h4 {
    font-size: 1.375rem !important;
    line-height: 1.3;
    margin-bottom: 5px;
    padding: 0 15px;
  }
}
.bestVideoSwiper p {
  font-size: 1.25rem;
  color: #5887c3;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-sizing: border-box;
  font-weight: bold;
  margin-bottom: 20px;
  padding: 0 20px;
}
@media all and (max-width: 767px) {
  .bestVideoSwiper p {
    font-size: 1.125rem;
    margin-bottom: 15px;
    padding: 0 15px;
  }
}
.bestVideoSwiper .videobx {
  position: relative;
  z-index: 10;
}
.bestVideoSwiper .imgbx {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  overflow: hidden;
}
.bestVideoSwiper .imgbx::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: #000;
}
.bestVideoSwiper .imgbx::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  background: url(../images/play-index.svg) no-repeat center center/contain;
  z-index: 3;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media all and (max-width: 767px) {
  .bestVideoSwiper .imgbx::after {
    width: 60px;
    height: 60px;
  }
}
.bestVideoSwiper .imgbx img,
.bestVideoSwiper .imgbx iframe {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  z-index: 1;
  left: 0;
}
.bestVideoSwiper .imgbx img {
  transition: 0.5s all ease-in-out;
}

.main p.dayline {
  color: #dd3737;
  font-size: 0.93rem;
  margin-top: 10px;
}
.main p.dayline span {
  display: block;
}
.main p.dayline .time {
  display: inline-block;
}
.main p.dayline + .dayline {
  margin-top: 0px;
}

.swiper-button-prev.arsy2,
.swiper-button-next.arsy2 {
  opacity: 0;
}
@media all and (max-width: 767px) {
  .swiper-button-prev.arsy2,
  .swiper-button-next.arsy2 {
    opacity: 1;
    width: 40px;
    height: 40px;
    right: 0px;
    top: auto;
    bottom: -10px;
    transform: translate(0, 0);
    background: url(../images/arrowlight-gray.svg) no-repeat center center/contain;
  }
  .swiper-button-prev.arsy2::after,
  .swiper-button-next.arsy2::after {
    display: none;
  }
}

.swiper-button-prev.arsy2 {
  left: 10px;
}

.swiper-button-next.arsy2 {
  right: 10px;
  transform: rotateZ(180deg);
}

.swiper-button-prev.arsy2.bestViedo,
.swiper-button-next.arsy2.bestViedo {
  top: 56%;
  box-shadow: none;
}

.swiper-button-prev.arsy2.bestViedo {
  left: 5px;
}

.swiper-button-next.arsy2.bestViedo {
  right: 5px;
}

.sticky_tab {
  height: 0;
  opacity: 0;
}
@media all and (max-width: 767px) {
  .sticky_tab {
    display: flex;
    height: auto;
    opacity: 1;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 10;
  }
  .sticky_tab li {
    display: none;
    position: relative;
  }
  .sticky_tab li a {
    width: 100%;
    font-size: 1.5rem;
    display: block;
    font-weight: bold;
    color: #000;
    background-color: transparent;
  }
  .sticky_tab li a:hover {
    background-color: transparent;
  }
  .sticky_tab li:first-child {
    display: block;
    text-align: left;
    margin-bottom: 20px;
  }
  .sticky_tab li:first-child::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: -5px;
    background-color: #5887c3;
    width: 60px;
    height: 2px;
  }
  .sticky_tab.fixed {
    position: fixed;
    top: 51px;
    left: 0;
    width: 100%;
    background-color: #fff;
    box-shadow: 0 0 10px 5px rgba(0, 0, 0, 0.3);
    z-index: 20;
  }
  .sticky_tab.fixed li {
    width: 33.3%;
    display: block;
    margin-bottom: 0;
  }
  .sticky_tab.fixed li:first-child::before {
    display: none;
  }
  .sticky_tab.fixed li.on a {
    color: #000;
    background-color: transparent;
    border-bottom: 4px solid #5887c3;
  }
  .sticky_tab.fixed a {
    font-size: 1.25rem;
    padding: 5px;
    text-align: center;
  }
}

@media all and (max-width: 767px) {
  #section-part3-1 .classSwiper .swiper-slide,
  #section-part3-2 .classSwiper .swiper-slide,
  #section-part3-3 .classSwiper .swiper-slide,
  #section-part3-4 .classSwiper .swiper-slide {
    opacity: 1;
    margin-bottom: 25px;
  }
}

@media all and (max-width: 767px) {
  #section-part3-1 .swiper-wrapper,
  #section-part3-2 .swiper-wrapper,
  #section-part3-3 .swiper-wrapper,
  #section-part3-4 .swiper-wrapper {
    display: block;
  }
}

.index .introCardBx {
  margin-top: 25px;
}

.btSwiper {
  transition: 0.8s all ease-in-out;
}
.btSwiper.ani {
  top: 0;
  opacity: 1;
}

.introCardBx {
  margin-bottom: 30px;
}
.introCardBx .introCard {
  width: 31.3%;
  margin-right: 3%;
  border-radius: 20px;
  background-color: #fff;
  padding: 40px;
  text-align: center;
  box-shadow: 0 0 13px rgba(36, 49, 63, 0.2);
  height: auto;
}
@media all and (max-width: 767px) {
  .introCardBx .introCard {
    width: 100%;
    margin-right: 0;
    padding: 15px;
  }
}
.introCardBx .introCard:nth-child(3n) {
  margin-right: 0;
}
.introCardBx .introCard .imgbx {
  width: 130px;
  margin: 0 auto;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .introCardBx .introCard .imgbx {
    margin-bottom: 0;
  }
}
.introCardBx .introCard p {
  font-size: 1.125rem;
}
@media all and (max-width: 767px) {
  .introCardBx .introCard p {
    font-size: 1rem;
  }
}
.introCardBx .introCard h4 {
  font-weight: bold;
  margin-bottom: 15px;
  font-size: 1.5rem;
}
@media all and (max-width: 767px) {
  .introCardBx .introCard h4 {
    margin-bottom: 5px;
    font-size: 1.25rem;
  }
}
.introCardBx .introCard .txt {
  padding: 15px 0;
  position: relative;
}
.introCardBx .introCard .txt::before, .introCardBx .introCard .txt::after {
  content: "";
  display: block;
  position: absolute;
  width: 30px;
  height: 30px;
  background: url(../images/introCard-textDeco.png) no-repeat center center/contain;
}
.introCardBx .introCard .txt::before {
  left: 0;
  top: -20px;
}
@media all and (max-width: 767px) {
  .introCardBx .introCard .txt::before {
    top: 0;
  }
}
.introCardBx .introCard .txt::after {
  right: 0;
  bottom: -20px;
  transform: rotatez(180deg);
}
@media all and (max-width: 767px) {
  .introCardBx .introCard .txt::after {
    bottom: -10px;
  }
}

@media all and (max-width: 767px) {
  .index .swiper {
    overflow: initial;
  }
  .index .swiper .swiper-slide {
    opacity: 0.3;
  }
  .index .swiper .swiper-slide.swiper-slide-active {
    opacity: 1;
  }
}
.index .swiper-horizontal > .swiper-pagination-bullets,
.index .swiper-pagination-bullets.swiper-pagination-horizontal,
.index .swiper-pagination-custom,
.index .swiper-pagination-fraction {
  position: relative;
  padding-top: 5px;
  bottom: 0;
  padding: 15px 50px 0px 50px;
  height: 37.19px;
  line-height: 1.1;
}
.index .swiper-pagination-bullet {
  border-radius: 10px;
  width: 10px;
  height: 6px;
}
.index .swiper-pagination-bullet-active {
  background: #ff3366;
  width: 35px;
}

.classSwiper {
  position: relative;
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  transition: 0.8s all ease-in-out;
}
.classSwiper.ani {
  top: 0;
  opacity: 1;
}

.classSwiper .swiper-slide {
  height: calc((100% - 30px) / 2);
  /* Center slide text vertically */
  display: flex;
  justify-content: center;
  align-items: center;
}

.index .arr-tC.class {
  margin-top: 0;
  margin-bottom: 0;
}
@media all and (max-width: 767px) {
  .index .arr-tC.class {
    margin-bottom: 30px;
    margin-top: 20px;
    position: relative;
    top: 10px;
  }
  .index .arr-tC.class.web {
    display: none;
  }
}

.index .arr-tC.class .arrow-bx {
  display: none;
}
@media all and (max-width: 767px) {
  .index .arr-tC.class .arrow-bx {
    display: block;
  }
}

.classSwiper.wrap {
  overflow: visible;
}
.classSwiper.wrap .swiper-slide {
  display: block;
}
@media all and (max-width: 767px) {
  .classSwiper.wrap {
    margin-left: 0;
    margin-right: 0;
  }
  .classSwiper.wrap .m-inline {
    display: flex;
  }
  .classSwiper.wrap .m-inline .img {
    min-width: 180px;
    margin-right: 8px;
    width: 40%;
  }
  .classSwiper.wrap .m-inline .m-rbx {
    width: 100%;
  }
  .classSwiper.wrap .m-inline .m-rbx h4 {
    font-size: 1.25rem;
    line-height: 1.3;
  }
  .classSwiper.wrap .m-inline .m-rbx p:first-of-type {
    display: none;
  }
  .classSwiper.wrap .m-inline .m-rbx p.price {
    font-size: 1.125rem;
    display: block !important;
  }
  .classSwiper.wrap .m-inline .m-rbx .or_price {
    font-size: 0.875rem;
  }
}
@media all and (max-width: 767px) {
  .classSwiper.wrap .myclassli .tag {
    display: none;
  }
}

.index-bn {
  position: relative;
}
@media all and (max-width: 767px) {
  .index-bn + .index-bn {
    margin-top: 20px;
  }
}

.index-bn:last-of-type {
  margin-bottom: 30px;
}

.tabsy2 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
@media all and (max-width: 767px) {
  .tabsy2 {
    overflow-x: scroll;
  }
}
.tabsy2 p.searchResult {
  font-size: 1.25rem;
  margin-bottom: 25px;
}
.tabsy2 p.searchResult span {
  color: #5887c3;
}
@media all and (max-width: 767px) {
  .tabsy2 p.searchResult {
    margin-bottom: 10px;
  }
}
.tabsy2 .tab li:first-child a,
.tabsy2 .tab li:last-child a,
.tabsy2 .tab a {
  border-radius: 40px;
  border: 1px solid #aaa;
  white-space: nowrap;
}
.tabsy2 .tab li + li {
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .tabsy2 .tab li + li {
    margin-left: 5px;
  }
}
.tabsy2 .tab {
  width: auto;
  padding: 0;
  margin-left: 0;
  justify-content: flex-start;
  overflow: auto;
}
.tabsy2 .tab a {
  padding: 0px 15px;
}
@media all and (max-width: 767px) {
  .tabsy2 .tab::-webkit-scrollbar {
    display: none;
  }
}
.tabsy2 li.on a {
  background-color: #5887c3;
  color: #fff;
  border: 1px solid #5887c3 !important;
}
.tabsy2 li.unread {
  position: relative;
}
.tabsy2 li.unread a {
  padding: 0 30px 0 20px;
}
.tabsy2 li.unread::after {
  content: "!";
  border-radius: 100%;
  background-color: #f24462;
  color: #fff;
  font-size: 15px;
  font-weight: bold;
  line-height: 18px;
  text-align: center;
  width: 20px;
  height: 20px;
  top: 50%;
  margin-top: -10px;
  right: 6px;
  position: absolute;
}
.tabsy2 select {
  position: relative;
  color: #626262;
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .tabsy2 select {
    font-size: 1.125rem;
  }
}

.choiceDataArea {
  display: flex;
  align-items: center;
  margin-left: -10px;
}
.choiceDataArea input {
  padding: 0 10px;
  margin: 0 10px;
  height: 40px;
  line-height: 40px;
  border: 1px solid #d2d2d2;
  color: #000;
  font-weight: 400;
  border-radius: 5px;
}
.choiceDataArea p {
  font-size: 1.25rem;
}
.choiceDataArea p span {
  color: #ff3366;
}
@media all and (max-width: 767px) {
  .choiceDataArea {
    width: 100%;
    display: block;
    text-align: center;
    margin-bottom: 15px;
  }
  .choiceDataArea input {
    margin: 0 10px 10px 0;
  }
}

.classSwiper.wrap .swiper-wrapper {
  display: flex;
  flex-wrap: wrap;
}

.classSwiper.wrap .swiper-wrapper .swiper-slide {
  width: 31.3%;
  margin-right: 3%;
  margin-bottom: 3%;
}
@media all and (max-width: 1200px) {
  .classSwiper.wrap .swiper-wrapper .swiper-slide {
    width: 48.5%;
  }
}
@media all and (max-width: 767px) {
  .classSwiper.wrap .swiper-wrapper .swiper-slide {
    opacity: 1;
    width: 100%;
    margin-right: 0;
    margin-bottom: 8%;
  }
  .classSwiper.wrap .swiper-wrapper .swiper-slide:last-child {
    margin-bottom: 20px;
  }
}

.classSwiper.wrap .swiper-wrapper .swiper-slide:nth-child(3n) {
  margin-right: 0;
}
@media all and (max-width: 1200px) {
  .classSwiper.wrap .swiper-wrapper .swiper-slide:nth-child(3n) {
    margin-right: 3%;
  }
}

@media all and (max-width: 1200px) {
  .classSwiper.wrap .swiper-wrapper .swiper-slide:nth-child(2n) {
    margin-right: 0;
  }
}
.bgsy-4 {
  position: relative;
}
.bgsy-4::before {
  content: "";
  width: 50%;
  height: 100%;
  background-color: #e8e8e8;
  position: absolute;
  right: 0;
  top: 0;
}
@media all and (max-width: 1200px) {
  .bgsy-4::before {
    display: none;
  }
}

.two-row {
  display: flex;
  flex-wrap: wrap;
}
.two-row .item {
  position: relative;
  padding-top: 40px;
  padding-bottom: 60px;
}
@media all and (max-width: 1200px) {
  .two-row .item {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}
.two-row .more.sw {
  right: 30px;
}
@media all and (max-width: 1200px) {
  .two-row .more.sw {
    right: 20px !important;
  }
}

.stockFu-item {
  width: 100%;
  padding-right: 0px;
  background-color: #f5f5f5;
  overflow: hidden;
  position: relative;
}
@media all and (max-width: 1200px) {
  .stockFu-item h2 {
    margin-left: 15px;
  }
}
@media all and (max-width: 1200px) {
  .stockFu-item .more.sw {
    top: 24px;
  }
}
@media all and (max-width: 767px) {
  .stockFu-item .arr-tC {
    margin-top: 20px;
  }
}
@media all and (max-width: 1200px) {
  .stockFu-item {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
    margin-left: -15px;
    margin-right: -15px;
    width: calc(100% + 30px);
  }
}
.stockFu-item .outer-contain {
  position: relative;
  width: 100%;
  margin-top: 30px;
  transition: 0.8s all ease-in-out;
}
.stockFu-item .outer-contain.ani {
  right: 0;
  opacity: 1;
}
@media all and (max-width: 1200px) {
  .stockFu-item .outer-contain {
    padding-bottom: inherit;
    padding: 0 15px 20px;
  }
}
@media all and (max-width: 1200px) {
  .stockFu-item .outer-contain .inner-contain {
    position: relative;
  }
}
.stockFu-item .bx {
  width: 100%;
  position: relative;
}
.stockFu-item .swiper {
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
}
.stockFu-item .swiper-slide {
  text-align: left;
  font-size: 18px;
  height: calc((100% - 30px) / 2);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media all and (max-width: 1200px) {
  .stockFu-item .swiper-slide {
    opacity: 0.3;
  }
  .stockFu-item .swiper-slide.swiper-slide-active {
    opacity: 1;
  }
}
.stockFu-item .swiper-slide:hover img {
  transform: scale(1.1);
}
.stockFu-item .arrow-bx {
  top: 20px;
}
@media all and (max-width: 1200px) {
  .stockFu-item .arrow-bx {
    top: 0;
  }
}
.stockFu-item h4 {
  font-size: 1.5rem;
  color: #000;
  font-weight: bold;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-sizing: border-box;
}
@media all and (max-width: 767px) {
  .stockFu-item h4 {
    font-size: 1.375rem;
  }
}
.stockFu-item p {
  font-size: 1.125rem;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-sizing: border-box;
}
.stockFu-item .imgbx {
  width: 100%;
  position: relative;
  padding-bottom: 66.66%;
  margin-bottom: 5px;
  overflow: hidden;
}
.stockFu-item .imgbx img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: 0.4s all ease-in-out;
}

.teacherSwiper .swiper-wrapper {
  flex-wrap: wrap;
  display: flex;
}
.teacherSwiper .swiper-wrapper.center {
  justify-content: center;
}
.teacherSwiper .swiper-slide {
  width: 9.8%;
  margin-right: 3%;
  display: block;
  text-align: center;
  padding-bottom: 15px;
}
.teacherSwiper .swiper-slide:nth-child(8n) {
  margin-right: 0;
}
@media all and (max-width: 1200px) {
  .teacherSwiper .swiper-slide {
    width: 14.1%;
  }
  .teacherSwiper .swiper-slide:nth-child(8n) {
    margin-right: 3%;
  }
  .teacherSwiper .swiper-slide:nth-child(6n) {
    margin-right: 0%;
  }
}
@media all and (max-width: 1200px) {
  .teacherSwiper .swiper-slide {
    width: 17.6%;
    opacity: 1 !important;
  }
  .teacherSwiper .swiper-slide:nth-child(6n) {
    margin-right: 3%;
  }
  .teacherSwiper .swiper-slide:nth-child(5n) {
    margin-right: 0%;
  }
}
@media all and (max-width: 767px) {
  .teacherSwiper .swiper-slide {
    width: 31.3%;
    opacity: 1 !important;
  }
  .teacherSwiper .swiper-slide .head {
    width: 90px;
    height: 90px;
  }
  .teacherSwiper .swiper-slide:nth-child(5n) {
    margin-right: 3%;
  }
  .teacherSwiper .swiper-slide:nth-child(3n) {
    margin-right: 0%;
  }
}
.teacherSwiper .swiper-slide p {
  color: #626262;
  font-size: 1.25rem;
  font-weight: bold;
  padding-top: 5px;
}
@media all and (max-width: 767px) {
  .teacherSwiper .swiper-slide p {
    font-size: 1.125rem;
  }
}
.teacherSwiper .swiper-slide .head {
  top: 0;
  margin: 0 auto;
  background-color: #fff;
}

.teacher-item {
  width: 40%;
  padding-left: 30px;
  background-color: #e8e8e8;
  display: none;
}
@media all and (max-width: 767px) {
  .teacher-item .arr-tC {
    margin-top: 10px;
  }
}
.teacher-item .more.sw {
  right: 0;
}
@media all and (max-width: 767px) {
  .teacher-item .more.sw {
    right: 15px;
  }
}
.teacher-item .outer-contain {
  position: relative;
  width: 100%;
  height: 665px;
  margin-top: 30px;
  transition: 0.8s all ease-in-out;
}
.teacher-item .outer-contain.ani {
  left: 0;
  opacity: 1;
}
@media all and (max-width: 767px) {
  .teacher-item .outer-contain {
    height: auto;
  }
}
.teacher-item .outer-contain .inner-contain {
  width: 100%;
  height: 100%;
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
}
@media all and (max-width: 767px) {
  .teacher-item .outer-contain .inner-contain {
    position: inherit;
  }
}
.teacher-item .swiper {
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}
.teacher-item .swiper-slide {
  text-align: left;
  height: calc((100% - 100px) / 5) !important;
  /* Center slide text vertically */
  display: flex;
  justify-content: center;
  align-items: flex-start;
  position: relative;
}
@media all and (max-width: 767px) {
  .teacher-item .swiper-slide {
    height: calc((100% - 25px) / 2) !important;
  }
}
.teacher-item .swiper-slide::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #bfbfbf;
  position: absolute;
  left: 0;
  bottom: -12px;
}
@media all and (max-width: 767px) {
  .teacher-item .swiper-slide::after {
    display: none;
  }
}
@media all and (max-width: 1200px) {
  .teacher-item {
    width: calc(100% + 40px);
    margin-right: -20px;
    margin-left: -20px;
    padding-right: 15px;
    padding-left: 15px;
  }
}
@media all and (max-width: 767px) {
  .teacher-item {
    width: calc(100% + 30px);
    margin-right: -15px;
    margin-left: -15px;
    padding-right: 15px;
    padding-left: 15px;
  }
}
.teacher-item .bx {
  width: 100%;
  position: relative;
}
.teacher-item .class-teacher {
  padding-bottom: 0;
}
@media all and (max-width: 767px) {
  .teacher-item .class-teacher {
    flex-direction: row;
  }
}
.teacher-item .class-teacher .head {
  top: 0;
  background-color: #fff;
}
.teacher-item .class-teacher .txt {
  position: relative;
  top: 20px;
  left: -10px;
}
.teacher-item .class-teacher .txt h4 {
  margin-bottom: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-sizing: border-box;
}
@media all and (max-width: 767px) {
  .teacher-item .class-teacher .txt h4 {
    position: relative;
    top: auto;
    left: auto;
  }
}
.teacher-item .class-teacher .txt p {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-sizing: border-box;
}

.main-bn + .in {
  padding-top: 15px;
}
@media all and (max-width: 1440px) {
  .main-bn + .in {
    padding-top: 30px;
  }
}

.over-hidden {
  overflow: hidden;
}

.block {
  position: relative;
  padding: 30px 0;
}
@media all and (max-width: 767px) {
  .block {
    padding: 20px 0;
  }
}
.block.first {
  padding-top: 0;
}
@media all and (max-width: 767px) {
  .block.first .breadcrumb {
    padding-top: 15px;
  }
}
.block.pink {
  background-color: #ff3366;
  color: #fff;
}
.block.pink h3 {
  color: #fff;
}
.block.lightGray {
  background-color: #eeeeee;
}
.block.lightGray .myclassli::before {
  display: none;
}
.block.blue {
  background-color: #cfdbe9;
}
.block.gray {
  background-color: #f1f1f1;
}
.block h3 {
  font-size: 3rem;
  font-weight: bold;
}
.block h4 {
  font-size: 1.75rem;
}
.block .btn-sy2 {
  background-color: #fff;
  color: #ff3366;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
  transition: 0.3s all ease-in-out;
}
.block .btn-sy2:hover {
  background-color: #ffdb01;
  color: #312057;
}

.tit-tick {
  justify-content: center;
}
.tit-tick span {
  display: inline-block;
  padding: 3px 20px 5px 45px;
  background-color: #ff8fa5;
  color: #fff;
  font-size: 1.5rem;
  border-radius: 30px;
  position: relative;
}
@media all and (max-width: 767px) {
  .tit-tick span {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 12px;
  }
}
.tit-tick span + span {
  margin-left: 13px;
}
@media all and (max-width: 767px) {
  .tit-tick span + span {
    margin-left: 0;
  }
}
.tit-tick span::before {
  content: "";
  display: block;
  position: absolute;
  left: 15px;
  top: 12px;
  width: 25px;
  height: 25px;
  background: url(../images/tit-tick.png) no-repeat center center/contain;
}

.btn-sy2 {
  padding: 3px 45px 6px 45px;
  font-size: 1.75rem;
  border-radius: 30px;
}

.roomi-intro {
  display: flex;
}
@media all and (max-width: 767px) {
  .roomi-intro {
    flex-direction: column;
  }
}
.roomi-intro-phone {
  width: 320px;
  margin-right: 30px;
  flex: 0 0 auto;
  margin-bottom: -75px;
  position: relative;
  z-index: 2;
}
.roomi-intro-txt {
  width: 100%;
}
.roomi-intro-txt .d-flex {
  justify-content: space-between;
}
@media all and (max-width: 1440px) {
  .roomi-intro-txt .d-flex {
    flex-wrap: wrap;
  }
}
.roomi-intro-txt .d-flex > p {
  max-width: 460px;
}
@media all and (max-width: 1440px) {
  .roomi-intro-txt .d-flex > p {
    max-width: 100%;
    margin-bottom: 10px;
  }
}
.roomi-intro .roomi-img {
  width: 300px;
}
.roomi-intro h4 {
  font-size: 1.31rem;
  padding-bottom: 3px;
  border-bottom: 1px solid #000;
  display: inline-block;
  font-weight: 500;
}
.roomi-intro .qr-bx {
  display: flex;
}
.roomi-intro .qr-bx a {
  display: inline-block;
  width: 140px;
  transition: 0.2s all ease-in-out;
}
.roomi-intro .qr-bx a + a {
  margin-left: 15px;
}
.roomi-intro .qr-bx a:hover {
  position: relative;
  top: -5px;
}

.remberMe input[type=checkbox] ~ label,
.login .forgetPs {
  transition: 0.3s all ease-in-out;
}
.remberMe input[type=checkbox] ~ label:hover,
.login .forgetPs:hover {
  color: #5c9cce;
}

.buy-ic {
  margin: 0 auto;
  width: 160px;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .buy-ic {
    width: 120px;
  }
}

.mailto {
  color: #8d4b95;
  border-bottom: 1px solid #8d4b95;
  padding-bottom: 2px;
}

.frame .tab {
  justify-content: flex-start;
}
@media all and (max-width: 767px) {
  .frame .tab {
    padding: 0;
  }
}
.frame .tab a {
  font-size: 1rem;
  padding: 5px 35px;
}
@media all and (max-width: 767px) {
  .frame .tab a {
    padding: 5px;
  }
}

.creditInput {
  display: flex;
  align-items: center;
  background-color: #fff;
  border-radius: 5px;
  border: 1px solid #d2d2d2;
}
.creditInput input,
.creditInput select {
  border: none;
  text-align: center;
}
.creditInput select {
  background: none;
  padding: 8px 0;
}

.row3 {
  flex-wrap: wrap;
}
.row3 > div {
  width: 31.3%;
  margin-right: 3%;
  margin-bottom: 3%;
}
@media all and (max-width: 767px) {
  .row3 > div {
    width: 100%;
    margin-right: 0;
    margin-bottom: 5%;
  }
}
.row3 > div:nth-child(3n) {
  margin-right: 0;
}
.row3 > div.w-100 {
  margin-right: 0;
}
@media all and (max-width: 767px) {
  .row3 > div.w-400x, .row3 > div.w-200x {
    max-width: 100%;
    width: 100%;
    margin-right: 0;
    margin-bottom: 10px;
  }
}

.bill.item {
  display: flex;
  align-items: center;
}
@media all and (max-width: 767px) {
  .bill.item {
    flex-wrap: wrap;
  }
}
@media all and (max-width: 767px) {
  .bill.item input {
    margin-top: 10px;
  }
}
.bill.item label.hasinput {
  width: 130px;
  flex: 0 0 auto;
}

.tit-g {
  position: relative;
}
@media all and (max-width: 767px) {
  .tit-g {
    margin-bottom: 20px;
  }
}
.tit-g.hasbtn {
  display: flex;
  justify-content: space-between;
}
@media all and (max-width: 767px) {
  .tit-g.hasbtn {
    flex-direction: column;
  }
}
.tit-g.hasbtn h2 {
  margin-bottom: 0;
}
.tit-g.hasbtn .rbx {
  flex: 0 0 auto;
}
@media all and (max-width: 767px) {
  .tit-g.hasbtn .rbx {
    width: 100%;
    margin-top: 15px;
  }
}
.tit-g.hasbtn .rbx .price {
  color: #5887c3;
  font-size: 1.875rem;
  font-weight: bold;
  text-align: right;
  top: -6px;
  position: relative;
}
@media all and (max-width: 767px) {
  .tit-g.hasbtn .rbx .price {
    top: 0;
  }
}
.tit-g.hasbtn .rbx .or_price {
  position: relative;
  text-decoration: line-through;
  vertical-align: middle;
  top: 0px;
  font-size: 1rem;
  color: #8c8c8c;
  padding-left: 5px;
  font-weight: 400;
  white-space: nowrap;
}
.tit-g.hasbtn .btn {
  right: 0;
  top: -5px;
  display: flex;
  justify-content: flex-end;
}
@media all and (max-width: 1200px) {
  .tit-g.hasbtn .btn {
    position: relative;
    top: 0;
    flex-wrap: wrap;
  }
}
.tit-g.hasbtn a {
  display: block;
  font-size: 1.375rem;
  background-color: #ff3366;
  padding: 4px 30px;
  border-radius: 40px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
  color: #fff;
  border: 1px solid #ff3366;
  text-align: center;
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .tit-g.hasbtn a {
    font-size: 1.125rem;
    padding: 2px 10px;
    margin: 0 0 10px 5px;
  }
}
.tit-g.hasbtn a.whiteBg {
  background-color: #fff;
  color: #ff3366;
}

h2.classNm {
  position: relative;
  padding-right: 260px;
}
@media all and (max-width: 1440px) {
  h2.classNm {
    margin-bottom: 40px;
  }
}
@media all and (max-width: 767px) {
  h2.classNm {
    padding-right: 0;
    font-size: 1.875rem;
    margin-bottom: 20px;
  }
}

.classInfo {
  margin-bottom: 30px;
  background: #fff;
  padding: 20px;
  border-radius: 10px;
}
.classInfo li {
  position: relative;
  padding-left: 20px;
  font-size: 1.125rem;
}
.classInfo li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}

.buyInfo-nmlast {
  position: absolute;
  right: 0;
  top: 0;
  display: flex;
}
@media all and (max-width: 767px) {
  .buyInfo-nmlast {
    position: relative;
    justify-content: center;
    margin-top: 25px;
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
}
.buyInfo-nmlast .addcart {
  background-color: #2b98ec;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: inline-block;
  position: relative;
}
@media all and (max-width: 767px) {
  .buyInfo-nmlast .addcart {
    width: 50px;
    height: 50px;
  }
}
.buyInfo-nmlast .addcart img {
  position: absolute;
  width: 35px;
  height: 35px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.buyInfo-nmlast .buynow {
  color: #fff;
  background-color: #ff3366;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  padding: 0 30px;
  border-radius: 30px;
  margin-left: 10px;
}
.buyInfo-nmlast .buynow.discount {
  background-color: #2b98ec;
}
@media all and (max-width: 767px) {
  .buyInfo-nmlast .buynow {
    font-size: 1.5rem;
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  .buyInfo-nmlast .buynow + .buynow {
    margin-top: 10px;
  }
}
@media all and (max-width: 767px) {
  .buyInfo-nmlast .addcart {
    margin-bottom: 10px;
  }
}

.stickyArea {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  bottom: 0;
  text-align: right;
  transition: 0.5s all ease-in-out;
  z-index: 2;
  opacity: 0;
  display: flex;
}
@media all and (max-width: 1440px) {
  .stickyArea {
    margin-bottom: 0px;
  }
}
@media all and (max-width: 767px) {
  .stickyArea {
    margin-bottom: 0px;
  }
}

.bt-buynow {
  flex: 1;
  background: linear-gradient(to right, #ba0f34, #fd3265);
  font-weight: 100;
  padding: 20px;
  text-align: center;
  width: 100%;
  display: block;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
@media all and (max-width: 767px) {
  .bt-buynow {
    padding: 15px;
  }
}
.bt-buynow span {
  color: #fff;
  font-size: 2rem;
  line-height: 1.3;
  font-weight: bold;
  display: inline-block;
}
.bt-buynow span span {
  margin-left: 8px;
}
.bt-buynow span span::before {
  display: none;
}
@media all and (max-width: 767px) {
  .bt-buynow span {
    font-size: 1.5rem;
  }
}

.stickyArea .goTop {
  display: block;
  position: absolute;
  margin-left: auto;
  margin-bottom: 80px;
  margin-right: 30px;
}
@media all and (max-width: 767px) {
  .stickyArea .goTop {
    margin-bottom: 90px;
    width: 70px;
    margin-right: 5px;
  }
}

.sideFixed {
  position: fixed;
  left: calc(50vw + 660px);
  bottom: 15%;
  z-index: 10;
  transition: all 1 ease-in;
  opacity: 0;
}
@media all and (max-width: 767px) {
  .sideFixed {
    left: auto;
    right: 10px;
  }
}

.goTop {
  display: block;
  width: 90px;
  margin-top: 5px;
}
@media all and (max-width: 767px) {
  .goTop {
    width: 80px;
  }
}

.goApp {
  display: block;
  width: 90px;
  border-radius: 50%;
  overflow: hidden;
  margin-top: 5px;
}
@media all and (max-width: 767px) {
  .goApp {
    width: 80px;
  }
}

.goGift {
  margin-top: 10px;
  display: block;
  width: 100px;
  border-radius: 10px;
  margin-left: -5px;
  color: #fff;
  text-align: center;
  font-size: 1.125rem;
  padding: 70px 0px 0px;
  height: 122px;
  background: url(../images/icon_go_gift.svg) no-repeat top center/contain;
}
@media all and (max-width: 767px) {
  .goGift {
    width: 80px;
    height: 100px;
    padding-top: 55px;
    margin: 0;
    font-size: 1rem;
  }
}

.goApppaln {
  position: fixed;
  right: 4vw;
  bottom: 15%;
  z-index: 10;
  transition: 0.2s opacity ease-in-out;
  opacity: 0;
}
.goApppaln a {
  margin-top: 10px;
  display: block;
  width: 120px;
  border-radius: 10px;
  color: #fff;
  text-align: center;
  font-size: 1.125rem;
  padding: 70px 5px 10px;
}
.goApppaln a.bt_topBuy {
  background: #ff0062 url(../images/icon_go_buy.svg) no-repeat top 10px center/50% auto;
}
.goApppaln a.bt_topTwo {
  background: #0169ca url(../images/icon_go_two.svg) no-repeat top 10px center/50% auto;
}
.goApppaln a.bt_trial {
  background: #ff0062 url(../images/icon_go_trial.svg) no-repeat top 10px center/50% auto;
}
.goApppaln a.bt_coupon {
  background: #ee9523 url(../images/icon_go_coupon.svg) no-repeat top 10px center/50% auto;
}
.goApppaln a.bt_gift {
  padding-top: 85px;
  height: 150px;
  background: url(../images/icon_go_gift.svg) no-repeat top center/contain;
}
.goApppaln a:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .goApppaln {
    left: auto;
    right: 10px;
  }
  .goApppaln a {
    width: 90px;
    font-size: 0.875rem;
    padding: 60px 5px 10px;
  }
  .goApppaln a.bt_gift {
    padding-top: 60px;
    height: 110px;
  }
}

.myclassli {
  padding: 20px;
  position: relative;
}
.myclassli * {
  position: relative;
  z-index: 2;
}
.myclassli .or_price {
  position: relative;
  text-decoration: line-through;
  vertical-align: middle;
  top: 0px;
  font-size: 1rem;
  color: #8c8c8c;
  padding-left: 5px;
  font-weight: 400;
  white-space: nowrap;
}
.myclassli::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  background-color: #fff;
  border-radius: 8px;
  z-index: -1;
}
.myclassli .info .subscribe {
  position: absolute;
  right: 0;
  top: 6px;
  color: #fff;
  background-color: #ab71cd;
  border-radius: 30px;
  font-size: 1rem;
  padding: 0 15px;
  font-weight: 400;
}
.myclassli .info .subscribe.onebuy {
  background-color: #7770d1;
}
@media all and (max-width: 767px) {
  .myclassli .info .subscribe {
    position: relative;
    right: auto;
    display: block;
    font-size: 0.93rem;
    text-align: center;
    margin-bottom: 10px;
    width: 100%;
    max-width: 120px;
  }
}
@media all and (max-width: 767px) {
  .myclassli {
    padding: 15px;
  }
}
.myclassli:hover img {
  transform: scale(1.1);
}
.myclassli:hover {
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
}
.myclassli:hover::before {
  z-index: 2;
}
.myclassli img {
  transition: 0.5s all ease-in-out;
}
.myclassli .imgbx {
  margin-bottom: 10px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  padding-bottom: 56.25%;
}
.myclassli .imgbx img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  -o-object-position: center top;
  object-position: center top;
}
.myclassli p.color-blue {
  color: #5887c3;
}
.myclassli p.teacher,
.myclassli p.tag {
  color: #6b8597;
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .myclassli p.teacher,
  .myclassli p.tag {
    font-size: 1.125rem;
  }
}
.myclassli h4 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
@media all and (max-width: 767px) {
  .myclassli h4 {
    font-size: 1.3rem;
    -webkit-line-clamp: 3;
  }
}
.myclassli h4 + p {
  min-height: 50px;
}
.myclassli p {
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4;
  color: #1b1b1b;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}
@media all and (max-width: 767px) {
  .myclassli p {
    font-size: 1rem;
  }
}

.classSwiper .myclassli p {
  -webkit-line-clamp: 2;
}

.vedio_box {
  margin-bottom: 0px;
}
.vedio_box .video-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  overflow: hidden;
}
.vedio_box .video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.vedio_box h5 {
  font-size: 1.5rem;
  color: #3d88b1;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .vedio_box h5 {
    font-weight: 500;
    font-size: 1.25rem;
    margin-bottom: 10px;
  }
}

.dottedline {
  width: 100%;
  border-top: 2px dotted #d1caca;
  display: block;
  margin-bottom: 20px;
}

.fblogin {
  display: block;
  width: 100%;
  border: 1px solid #1b74e4;
  padding: 8px 20px;
  text-align: center;
  border-radius: 5px;
  color: #fff;
  margin-bottom: 10px;
  background-color: #1b74e4;
  transition: 0.2s all ease-in-out;
}
.fblogin:hover {
  background-color: #348bf7;
}
.fblogin span {
  display: inline-block;
  width: 25px;
  margin-right: 10px;
  vertical-align: middle;
  position: relative;
  top: -2px;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.mb-10.set.d-flex {
  margin-top: -10px;
}

.frame.big {
  padding: 40px 0;
}

.noinfo-cir {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background-color: #c5c5c5;
  margin: 0 auto;
  margin-bottom: 15px;
  position: relative;
}
.noinfo-cir.lighterbg {
  background-color: #eeeeee;
}
.noinfo-cir img {
  width: 60px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.noinfo-cir + h4 {
  color: #0f1c38;
  font-size: 2.25rem;
  text-align: center;
  margin-bottom: 40px;
}
@media all and (max-width: 767px) {
  .noinfo-cir + h4 {
    font-size: 1.5rem;
    margin-bottom: auto;
  }
}

.m-top-m {
  margin-top: 25px;
}

header.subW .in {
  max-width: 1680px;
}
header.subW .header-logo {
  font-size: 1.875rem;
}
@media all and (max-width: 767px) {
  header.subW .header-logo {
    font-size: 1.3rem;
  }
}
header.subW .header-logo img {
  width: 160px;
}
@media all and (max-width: 767px) {
  header.subW .header-logo img {
    width: 130px;
  }
}
header.subW .pageMenu-btn {
  top: 50%;
  transform: translateY(-75%);
}

footer.subW .logo {
  font-size: 1.5rem;
}
footer.subW .logo img {
  width: 150px;
  margin-right: 10px;
  position: relative;
  top: -3px;
}
@media all and (max-width: 767px) {
  footer.subW .logo img {
    margin-right: 5px;
  }
}

p.bigger {
  font-size: 2.25rem;
  text-align: center;
  color: #000;
  line-height: 1.3;
  margin-bottom: 40px;
}
@media all and (max-width: 767px) {
  p.bigger {
    font-size: 1.5rem;
    margin-bottom: 20px;
    line-height: 1.6;
  }
}
p.bigger span {
  font-size: 3rem;
  display: block;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  p.bigger span {
    font-size: 2rem;
  }
}

.subW_banner {
  margin-top: -20px;
}

.subW_tab {
  display: flex;
  margin-bottom: 25px;
  margin-top: -10px;
}
@media all and (max-width: 767px) {
  .subW_tab {
    margin-bottom: 20px;
    margin-top: -5px;
  }
}
.subW_tab li {
  width: 100%;
}
.subW_tab li a {
  display: block;
  padding: 15px 5px;
  background-color: #535353;
  color: #fff;
  font-size: 1.875rem;
  text-align: center;
  width: 100%;
  transition: 0.3s all ease-in-out;
}
.subW_tab li a:hover {
  background-color: #696969;
}
@media all and (max-width: 767px) {
  .subW_tab li a {
    font-size: 1rem;
    padding: 10px 0;
  }
}
.subW_tab li.on a {
  background-color: #0f1c38;
  color: #00d2ff;
}
.subW_tab li.on a:hover {
  background-color: #254280;
}
.subW_tab li + li {
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .subW_tab li + li {
    margin-left: 3px;
  }
}
.subW_tab li:last-of-type a {
  background-color: #f5cd01;
  color: #000;
}
.subW_tab li:last-of-type a:hover {
  background-color: #ffda24;
}

.reportSwiper,
.articleSwiper {
  padding-bottom: 40px;
}
.reportSwiper .swiper-pagination-bullet,
.articleSwiper .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  margin: 0 8px !important;
}
@media all and (max-width: 767px) {
  .reportSwiper .swiper-pagination-bullet,
  .articleSwiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin: 0 5px !important;
  }
}
.reportSwiper .swiper-pagination-bullet-active,
.articleSwiper .swiper-pagination-bullet-active {
  background-color: #00a0e9;
}
.reportSwiper .swiper-horizontal > .swiper-pagination-bullets,
.reportSwiper .swiper-pagination-bullets.swiper-pagination-horizontal,
.reportSwiper .swiper-pagination-custom,
.reportSwiper .swiper-pagination-fraction,
.articleSwiper .swiper-horizontal > .swiper-pagination-bullets,
.articleSwiper .swiper-pagination-bullets.swiper-pagination-horizontal,
.articleSwiper .swiper-pagination-custom,
.articleSwiper .swiper-pagination-fraction {
  bottom: 0;
}

.articleSwiper {
  padding-bottom: 35px;
  margin-bottom: 30px;
}
@media all and (max-width: 767px) {
  .articleSwiper {
    padding-bottom: 30px;
    margin-bottom: 20px;
  }
}

.techIntro {
  padding: 30px 35px;
  display: flex;
  margin-bottom: 25px;
}
.techIntro.new {
  padding: 40px 20px;
}
@media all and (max-width: 767px) {
  .techIntro.new {
    padding: 20px 0 0 0;
    margin-bottom: 0;
  }
}
@media all and (max-width: 767px) {
  .techIntro {
    flex-direction: column;
    padding: 20px 15px;
  }
}
.techIntro .lbx {
  width: 130px;
  flex: 0 0 auto;
}
@media all and (max-width: 767px) {
  .techIntro .lbx {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    border-bottom: 1px solid #cfcfcf;
    padding-bottom: 10px;
    margin-bottom: 10px;
    flex-direction: column;
  }
}
.techIntro .rbx {
  width: 100%;
  padding-left: 30px;
  margin-left: 20px;
  border-left: 1px solid #cfcfcf;
}
@media all and (max-width: 767px) {
  .techIntro .rbx {
    padding-left: 0;
    margin-left: 0;
    border: none;
  }
}
.techIntro .head {
  width: 105px;
  height: 105px;
  overflow: hidden;
  background-color: #ffc200;
  border-radius: 50%;
  position: relative;
  margin: 0 auto;
  flex: 0 0 auto;
}
@media all and (max-width: 767px) {
  .techIntro .head {
    margin: 0;
    margin-right: 10px;
  }
}
.techIntro .head .imgbx {
  width: 100%;
  padding-bottom: 100%;
  position: relative;
}
.techIntro .head .imgbx img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.techIntro h4 {
  color: #b155a1;
  font-size: 1.125rem;
  margin-bottom: 5px;
}
.techIntro h4 + p {
  line-height: 1.9;
}
.techIntro .head + p {
  margin-top: 10px;
  font-size: 1.3rem;
  line-height: 1.5;
  color: #313131;
}
.techIntro .head + p span {
  display: block;
}
@media all and (max-width: 767px) {
  .techIntro .head + p span {
    display: inline-block;
  }
}
.techIntro li {
  margin-bottom: 5px;
}
@media all and (max-width: 767px) {
  .techIntro li {
    font-size: 1.125em;
  }
}

.ad-blueBG {
  background-color: #eee;
  padding: 35px 15px;
}
.ad-blueBG:last-of-type {
  margin-bottom: -20px;
}
@media all and (max-width: 767px) {
  .ad-blueBG:last-of-type {
    margin-bottom: -10px;
  }
}
.ad-blueBG.dark {
  background-color: #dfdfdf;
}
.ad-blueBG .in {
  max-width: 1280px;
  position: relative;
  align-items: center;
  justify-content: center;
}
.ad-blueBG .in.vedio_box {
  display: block;
  max-width: 1280px;
  padding: 0;
  margin-left: -10px;
  margin-right: -10px;
}
.ad-blueBG .tC {
  position: relative;
}
.ad-blueBG .tC::before {
  content: "Congratulations";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  color: #999;
  top: -20px;
  opacity: 0.15;
  font-size: 4rem;
}
@media all and (max-width: 767px) {
  .ad-blueBG .tC::before {
    font-size: 2.5rem;
    top: -15px;
  }
}
.ad-blueBG .tits1 {
  display: inline-block;
  font-size: 2rem;
  position: relative;
  z-index: 1;
  margin-top: 20px;
  font-weight: bold;
  margin-bottom: 5px;
}
@media all and (max-width: 767px) {
  .ad-blueBG .tits1 {
    font-size: 1.5rem;
    margin-top: 10px;
  }
}
.ad-blueBG .tits1 span {
  font-size: 3rem;
  margin: 0 10px;
}
@media all and (max-width: 767px) {
  .ad-blueBG .tits1 span {
    font-size: 2rem;
    margin: 0 5px;
  }
}
.ad-blueBG p {
  font-size: 1.5rem;
  background-color: #fee202;
  color: #fff;
  display: inline-block;
  padding: 2px 25px;
  border-radius: 40px;
  margin-bottom: 20px;
  COLOR: #2d2903;
  FONT-WEIGHT: 500;
}
@media all and (max-width: 767px) {
  .ad-blueBG p {
    font-size: 1.25rem;
  }
}
.ad-blueBG p + p {
  display: block;
  background: transparent;
  margin-top: -15px;
  color: #ee9523;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .ad-blueBG {
    padding: 25px 10px;
  }
}
.ad-blueBG .adgArea {
  width: 47.5%;
  overflow: hidden;
  margin-right: 5%;
  border-radius: 10px;
}
.ad-blueBG .adgArea.megz {
  width: 400px;
  max-width: 35%;
}
@media all and (max-width: 767px) {
  .ad-blueBG .adgArea.megz {
    width: 100%;
    max-width: 100%;
  }
}
.ad-blueBG .adgArea:nth-child(2n) {
  margin-right: 0;
}
@media all and (max-width: 767px) {
  .ad-blueBG .adgArea:nth-child(2n) {
    margin-bottom: 10px;
  }
}
@media all and (max-width: 767px) {
  .ad-blueBG .adgArea {
    width: 100%;
    margin-right: 0;
    margin-bottom: 25px;
  }
}

.edit_box .img-full {
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 10px;
}

.edit_box p {
  display: block;
  line-height: 26px;
  letter-spacing: 1.5px;
  margin-bottom: 20px;
  text-align: justify;
}

.productBx {
  padding-top: 20px;
}

.productItem {
  position: relative;
  display: flex;
  padding-bottom: 40px;
  align-items: center;
}
@media all and (max-width: 1200px) {
  .productItem {
    flex-direction: column-reverse;
    align-items: center;
    padding-bottom: 80px;
  }
}
.productItem .imgbx-phone {
  width: 500px;
  flex: 0 0 auto;
  margin-left: 40px;
  margin-bottom: 20px;
  position: relative;
  transition: 0.3s all ease-in-out;
}
.productItem .imgbx-phone:hover {
  opacity: 0.9;
}
@media all and (max-width: 1200px) {
  .productItem .imgbx-phone {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
    margin-bottom: 10px;
  }
}
@media all and (max-width: 1200px) {
  .productItem .txt {
    padding-top: 0px;
    min-height: auto;
  }
}
.productItem p {
  color: #1b1b1b;
  font-size: 1.5rem;
  line-height: 1.8;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media all and (max-width: 767px) {
  .productItem p {
    font-size: 1.125rem;
  }
}
.productItem h3 {
  font-size: 3.75rem;
  color: #1b1b1b;
  margin-right: 20px;
  margin-bottom: 0;
  font-weight: bold;
}
@media all and (max-width: 1440px) {
  .productItem h3 {
    font-size: 2.5rem;
  }
}
@media all and (max-width: 767px) {
  .productItem h3 {
    font-size: 1.875rem;
    margin-right: 10px;
  }
}
.productItem .author {
  color: #6b8597;
  font-size: 1.875rem;
  position: relative;
  top: 15px;
}
@media all and (max-width: 1440px) {
  .productItem .author {
    top: 10px;
    font-size: 1.5rem;
  }
}
@media all and (max-width: 767px) {
  .productItem .author {
    font-size: 1.25rem;
    top: 4px;
  }
}
.productItem .imgbx {
  width: 500px;
  flex: 0 0 auto;
}
.productItem .tit {
  display: flex;
  align-items: center;
  font-weight: bold;
  margin-bottom: 40px;
}
@media all and (max-width: 1200px) {
  .productItem .tit {
    margin-bottom: 20px;
  }
}
@media all and (max-width: 767px) {
  .productItem .tit {
    margin-bottom: 10px;
  }
}
.productItem .logo {
  width: 60px;
  height: 60px;
  vertical-align: middle;
  display: inline-block;
  margin-right: 20px;
}
@media all and (max-width: 767px) {
  .productItem .logo {
    width: 40px;
    height: 40px;
    margin-right: 10px;
  }
}
.productItem .logo .img {
  position: relative;
  width: 100%;
  padding-bottom: 100%;
}
.productItem .logo .img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.productItem .linkBx {
  display: flex;
  margin-top: 80px;
}
@media all and (max-width: 1200px) {
  .productItem .linkBx {
    margin-top: 50px;
  }
}
@media all and (max-width: 767px) {
  .productItem .linkBx {
    margin-top: 30px;
    flex-wrap: wrap;
    justify-content: center;
  }
}
.productItem .linkBx span {
  display: inline-block;
  width: 30px;
  height: 30px;
  background-repeat: no-repeat;
  background-size: 30px auto;
  background-position: center center;
  position: relative;
  top: 4px;
  margin-right: 5px;
}
@media all and (max-width: 767px) {
  .productItem .linkBx span {
    width: 25px;
    height: 25px;
    background-size: 25px auto;
  }
}
.productItem .linkBx .ios {
  background-image: url(../images/download-ios.svg);
}
.productItem .linkBx .adr {
  background-image: url(../images/download-adr.svg);
}
.productItem .linkBx .intro {
  background-image: url(../images/download-intro.svg);
}
.productItem .linkBx a {
  text-align: center;
  background-color: #e83464;
  color: #fff;
  font-size: 1.5rem;
  padding: 10px;
  display: block;
  width: 220px;
  border-radius: 80px;
  transition: 0.3s all ease-in-out;
  white-space: nowrap;
}
@media all and (max-width: 1200px) {
  .productItem .linkBx a {
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  .productItem .linkBx a {
    font-size: 1.125rem;
    padding: 10px 0 13px 0;
    width: 80%;
  }
}
.productItem .linkBx a:hover {
  opacity: 0.8;
}
.productItem .linkBx a + a {
  margin-left: 25px;
}
@media all and (max-width: 767px) {
  .productItem .linkBx a + a {
    margin-left: 0px;
    margin-top: 10px;
  }
}
.productItem .decoLine {
  width: 100%;
  height: 43px;
  position: absolute;
  bottom: -8px;
  left: 0;
}
.productItem:nth-child(odd) {
  flex-direction: row-reverse;
}
@media all and (max-width: 1200px) {
  .productItem:nth-child(odd) {
    flex-direction: column-reverse;
  }
}
.productItem:nth-child(odd) .imgbx-phone {
  margin-left: 0;
  margin-right: 40px;
}
@media all and (max-width: 1200px) {
  .productItem:nth-child(odd) .imgbx-phone {
    margin-right: 0;
  }
}
.productItem:last-child {
  padding-bottom: 40px;
}
.productItem:last-child .decoLine {
  display: none;
}

.pro-name {
  margin-bottom: 20px;
  font-size: 3.75rem;
  color: #1b1b1b;
  font-weight: bold;
}
@media all and (max-width: 1200px) {
  .pro-name {
    font-size: 2.25em;
    margin-bottom: 15px;
  }
}
@media all and (max-width: 1200px) {
  .pro-name {
    margin-bottom: 10px;
  }
}
.pro-name span {
  display: inline-block;
  width: 60px;
  margin-right: 20px;
  position: relative;
  top: 7px;
}
@media all and (max-width: 1200px) {
  .pro-name span {
    width: 40px;
    margin-right: 10px;
  }
}

.pro-name + p {
  font-size: 1.875rem;
}
@media all and (max-width: 767px) {
  .pro-name + p {
    font-size: 1.5rem;
  }
}

.pro-list {
  counter-reset: num;
  margin-bottom: 30px;
}
.pro-list li {
  position: relative;
  margin-bottom: 5px;
}
@media all and (max-width: 767px) {
  .pro-list li {
    margin-bottom: 10px;
  }
}
.pro-list li::before {
  content: "";
  width: 30px;
  height: 30px;
  display: inline-block;
  background: url(../images/goodIcon.png) no-repeat center center/contain;
  position: relative;
  top: 6px;
  margin-right: 5px;
}
@media all and (max-width: 767px) {
  .pro-list li::before {
    position: absolute;
    left: 0;
    top: 0;
  }
}
.pro-list .tit {
  color: #d40000;
  font-size: 1.25rem;
  border-bottom: 1px solid #d40000;
  display: inline-block;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .pro-list .tit {
    font-size: 1.125rem;
    margin-left: 40px;
  }
}
.pro-list .tit::before {
  counter-increment: num;
  content: counter(num) ". ";
}
.pro-list p {
  font-size: 1.25rem;
  padding-left: 38px;
}
@media all and (max-width: 767px) {
  .pro-list p {
    font-size: 1.125rem;
    padding-left: 40px;
  }
}

.pro-p {
  font-size: 1.5rem;
  font-weight: bold;
  color: #1b1b1b;
  margin-bottom: 10px;
}
@media all and (max-width: 767px) {
  .pro-p {
    margin-bottom: 5px;
    font-size: 1.25rem;
  }
}

.pro-tab {
  background-color: #eeeeee;
  padding: 0px 20px 0px 20px;
  display: flex;
  margin-bottom: 25px;
}
@media all and (max-width: 767px) {
  .pro-tab {
    margin-left: -15px;
    margin-right: -15px;
    position: relative;
  }
  .pro-tab::before {
    content: "";
    width: 30px;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background-color: #eee;
    z-index: 2;
  }
  .pro-tab::after {
    content: "";
    width: 30px;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    background-color: #eee;
    z-index: 2;
  }
}
@media all and (max-width: 767px) {
  .pro-tab {
    padding: 0 30px 0 30px;
  }
}
.pro-tab .swiper-button-next:after,
.pro-tab .swiper-button-prev:after {
  display: none;
}
.pro-tab .swiper-button-next,
.pro-tab .swiper-button-prev {
  background: url(../images/other-next.png) no-repeat center center/contain;
  width: 20px;
  z-index: 4;
  transition: 0.2s opacity ease-in-out;
}
.pro-tab .swiper-button-next:hover,
.pro-tab .swiper-button-prev:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .pro-tab .swiper-button-next,
  .pro-tab .swiper-button-prev {
    right: 10px;
    width: 12px;
  }
}
.pro-tab .swiper-button-prev {
  background-image: url(../images/other-prev.png);
}
@media all and (max-width: 767px) {
  .pro-tab .swiper-button-prev {
    left: 10px;
  }
}

.pro-tab li {
  width: 100%;
  text-align: center;
}
.pro-tab li.on a {
  color: #009de2;
  border-bottom: 3px solid #009de2;
  background-color: transparent;
  font-weight: bold;
}

.pro-tab a {
  font-size: 1.375rem;
  color: #434343;
  padding: 20px 0 10px 0;
  width: 100%;
  display: block;
  transition: 0.2s opacity ease-in-out;
}
.pro-tab a:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .pro-tab a {
    padding: 12px 0 12px 0;
  }
}

.otherProduct {
  margin-bottom: 30px;
  position: relative;
}
@media all and (max-width: 767px) {
  .otherProduct {
    margin-bottom: 20px;
    margin-top: 30px;
  }
}
.otherProduct h5 {
  color: #1b1b1b;
  font-size: 2.18rem;
  margin-bottom: 10px;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .otherProduct h5 {
    font-size: 1.875rem;
    text-align: center;
  }
}
.otherProduct h5 span {
  display: inline-block;
  width: 50px;
  position: relative;
  top: 7px;
  margin-right: 10px;
}
@media all and (max-width: 767px) {
  .otherProduct h5 span {
    width: 35px;
  }
}
.otherProduct p {
  font-size: 1.06rem;
  flex: 1;
}
.otherProduct .otherSwiper {
  padding: 0 40px;
  position: relative;
}
@media all and (max-width: 767px) {
  .otherProduct .otherSwiper {
    padding: 0 30px;
  }
}
.otherProduct .otherSwiper::before {
  content: "";
  position: absolute;
  top: 0;
  left: -2px;
  width: 43px;
  height: 100%;
  background-color: #fff;
  z-index: 2;
}
@media all and (max-width: 767px) {
  .otherProduct .otherSwiper::before {
    width: 33px;
  }
}
.otherProduct .otherSwiper::after {
  content: "";
  position: absolute;
  top: 0;
  right: -2px;
  width: 43px;
  height: 100%;
  background-color: #fff;
  z-index: 2;
}
@media all and (max-width: 767px) {
  .otherProduct .otherSwiper::after {
    width: 33px;
  }
}
.otherProduct .swiper-slide {
  padding: 0 25px;
  position: relative;
  transition: 0.2s opacity ease-in-out;
}
.otherProduct .swiper-slide:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .otherProduct .swiper-slide {
    padding: 0;
  }
}
.otherProduct .swiper-slide + .swiper-slide {
  border-left: 1px solid #e5e5e5;
}
.otherProduct .swiper-button-next:after,
.otherProduct .swiper-button-prev:after {
  display: none;
}
.otherProduct .swiper-button-next,
.otherProduct .swiper-button-prev {
  background: url(../images/other-next.png) no-repeat center center/contain;
  width: 20px;
  z-index: 4;
  transition: 0.2s opacity ease-in-out;
}
.otherProduct .swiper-button-next:hover,
.otherProduct .swiper-button-prev:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .otherProduct .swiper-button-next,
  .otherProduct .swiper-button-prev {
    right: 0;
    width: 15px;
  }
}
.otherProduct .swiper-button-prev {
  background-image: url(../images/other-prev.png);
}
@media all and (max-width: 767px) {
  .otherProduct .swiper-button-prev {
    left: 0;
  }
}

.pro-in {
  display: flex;
  align-items: flex-start;
  margin-bottom: 30px;
}
@media all and (max-width: 1200px) {
  .pro-in {
    flex-direction: column;
  }
}
.pro-in .bigArea {
  width: 100%;
  overflow: hidden;
}
.pro-in .bigArea .pagesize {
  max-width: 800px;
}
@media all and (max-width: 1200px) {
  .pro-in .bigArea {
    width: 100%;
  }
}
@media all and (max-width: 767px) {
  .pro-in .bigArea {
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-right: -15px;
    margin-top: -25px;
  }
}
.pro-in .aside {
  width: 265px;
  flex: 0 0 auto;
  margin-left: 20px;
}
.pro-in .aside.asideFixed {
  position: fixed;
  top: 90px;
  right: 20px;
  z-index: 40;
}
@media all and (max-width: 1200px) {
  .pro-in .aside {
    width: 100%;
    margin-left: 0;
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
  }
}
.pro-in .fm {
  padding: 10px 15px;
  border-radius: 4px;
  box-shadow: 0 0 6px 2px rgba(0, 0, 0, 0.15);
  background-color: #fff;
  position: relative;
}
@media all and (max-width: 1200px) {
  .pro-in .fm {
    width: 48%;
    margin-right: 4%;
    margin-bottom: 10px;
  }
}
@media all and (max-width: 767px) {
  .pro-in .fm {
    width: 100%;
    margin-right: 0;
  }
}
.pro-in .fm:nth-child(2n) {
  margin-right: 0;
}
.pro-in .fm + .fm {
  margin-top: 15px;
}
@media all and (max-width: 1200px) {
  .pro-in .fm + .fm {
    margin-top: 0;
  }
}
@media all and (max-width: 767px) {
  .pro-in .fm + .fm {
    margin-top: 5px;
  }
}
.pro-in .fm h5 {
  color: #434343;
  font-size: 1.375rem;
}
.pro-in .fm h5 span {
  color: #da704c;
  font-size: 1rem;
  margin-top: -2px;
  display: block;
}
.pro-in .fm .price {
  font-size: 1.8rem;
  color: #000;
  font-weight: bold;
}
.pro-in .fm .btn {
  width: calc(100% - 30px);
  display: block;
  border-radius: 40px;
  padding: 8px;
  background-color: #e83464;
  color: #ffffff;
  font-size: 1.5rem;
  text-align: center;
  font-weight: bold;
  transition: 0.2s opacity ease-in-out;
  width: auto;
  font-size: 1.125rem;
  padding: 2px 20px;
  position: absolute;
  right: 12px;
  bottom: 15px;
}
.pro-in .fm .btn:hover {
  opacity: 0.8;
}

.class-mainBanner {
  position: relative;
  margin-top: -20px;
  height: auto;
  padding-bottom: 28.64%;
}
@media all and (max-width: 1440px) {
  .class-mainBanner {
    height: auto;
    padding-bottom: 28.64%;
  }
}
@media all and (max-width: 1440px) {
  .class-mainBanner {
    margin-top: -15px;
  }
}
@media all and (max-width: 767px) {
  .class-mainBanner {
    height: auto;
    padding-bottom: 100% !important;
  }
}
.class-mainBanner .play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100px;
  height: 100px;
  background: url(../images/play-index.svg) no-repeat center center/contain;
  z-index: 8;
}
@media all and (max-width: 1200px) {
  .class-mainBanner .play {
    width: 80px;
    height: 80px;
  }
}
.class-mainBanner.nomask::after {
  display: none;
}
.class-mainBanner::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.25);
  display: none;
}
.class-mainBanner img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.class-mainBanner .area {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 1280px;
  padding: 0 15px;
  color: #fff;
  z-index: 5;
}
@media all and (max-width: 767px) {
  .class-mainBanner .area {
    padding: 0 15px;
  }
}
.class-mainBanner .txt {
  max-width: calc(50% - 50px);
}
@media all and (max-width: 1200px) {
  .class-mainBanner .txt {
    max-width: 100%;
  }
}
.class-mainBanner p.teacher {
  font-size: 1.5rem;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .class-mainBanner p.teacher {
    font-size: 1.25rem;
  }
}
.class-mainBanner h3 {
  font-size: 3rem;
  color: #fff;
  font-weight: bold;
  line-height: 1.2;
  margin-bottom: 20px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  white-space: normal;
}
@media all and (max-width: 767px) {
  .class-mainBanner h3 {
    font-size: 1.875rem;
  }
}
.class-mainBanner h5 {
  font-size: 1.5rem;
  margin-bottom: 50px;
  line-height: 1.3;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
}
@media all and (max-width: 767px) {
  .class-mainBanner h5 {
    font-size: 1.25rem;
    margin-bottom: 30px;
  }
}
.class-mainBanner .time {
  font-size: 1.5rem;
}
@media all and (max-width: 767px) {
  .class-mainBanner .time {
    font-size: 1.25rem;
  }
}
.class-mainBanner .time span {
  color: #fff134;
}
.class-mainBanner .btn {
  display: flex;
  margin-top: 25px;
}
.class-mainBanner .btn a {
  display: block;
  font-size: 1.75rem;
  background-color: #ff3366;
  padding: 8px 35px;
  border-radius: 40px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
}
.class-mainBanner .btn a:hover {
  opacity: 0.9;
}
@media all and (max-width: 767px) {
  .class-mainBanner .btn a {
    width: 50%;
    text-align: center;
    padding: 6px 5px;
    font-size: 1.25rem;
  }
}
.class-mainBanner .btn a.whiteBg {
  background-color: #fff;
  color: #ff3366;
}
.class-mainBanner .btn a + a {
  margin-left: 15px;
}

.class-tab {
  display: flex;
  justify-content: center;
  border-bottom: 1px solid #e5e5e5;
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  top: 70px;
  width: 100%;
  z-index: 10;
  background: #fff;
}
@media all and (max-width: 1200px) {
  .class-tab {
    overflow-x: scroll;
  }
  .class-tab::-webkit-scrollbar {
    display: none;
  }
}
@media all and (max-width: 767px) {
  .class-tab {
    justify-content: flex-start;
  }
}
.class-tab a {
  padding: 10px 20px 12px 20px;
  color: #3a3a3a;
  display: block;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 2;
  transition: 0.2s all ease-in-out;
  white-space: nowrap;
}
.class-tab a:hover {
  color: #5887c3;
}
@media all and (max-width: 1200px) {
  .class-tab a {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media all and (max-width: 1200px) {
  .class-tab a {
    padding-left: 10px;
    padding-right: 10px;
  }
}
@media all and (max-width: 767px) {
  .class-tab a {
    padding: 5px 10px 12px 10px;
    font-size: 1.125rem;
    letter-spacing: 0;
  }
}
@media all and (max-width: 374px) {
  .class-tab a {
    padding: 4px 10px 8px 10px;
    font-size: 1.125rem;
    letter-spacing: 0;
  }
}
.class-tab li {
  position: relative;
}
.class-tab li.active::before {
  background: linear-gradient(to right, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
}
.class-tab li::before {
  content: "";
  width: 100%;
  height: 4px;
  border-radius: 10px;
  position: absolute;
  left: 0;
  bottom: 0;
  background: #fff;
}
@media all and (max-width: 767px) {
  .class-tab li {
    text-align: center;
  }
}
@media all and (max-width: 374px) {
  .class-tab li {
    width: auto;
    text-align: center;
  }
}
.class-tab li + li {
  margin-left: 1%;
}
@media all and (max-width: 1200px) {
  .class-tab li + li {
    margin-left: 0%;
  }
}
@media all and (max-width: 767px) {
  .class-tab li + li {
    margin-left: 0;
  }
}

.class-tab + .lightGray {
  padding-top: 40px;
  color: #000;
}
@media all and (max-width: 1200px) {
  .class-tab + .lightGray {
    padding-top: 20px;
  }
}

.lightGray {
  background-color: #f5f5f5;
}
.lightGray .myclassli::before {
  background-color: transparent;
}
.lightGray .tit-g .more {
  top: 4px;
}

.class-teacher {
  display: flex;
  padding-bottom: 40px;
  position: relative;
}
@media all and (max-width: 767px) {
  .class-teacher {
    flex-direction: column;
    align-items: center;
  }
}
.class-teacher .head {
  width: 105px;
  height: 105px;
  flex: 0 0 auto;
  margin-right: 30px;
  background-color: #344584;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  top: 30px;
}
@media all and (max-width: 767px) {
  .class-teacher .head {
    top: 0;
    margin-bottom: 5px;
    margin-right: 0;
  }
}
.class-teacher .head .imgbx {
  width: 100%;
  padding-bottom: 100%;
  position: relative;
}
.class-teacher .head .imgbx img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.class-teacher .txt {
  width: 100%;
}
.class-teacher .txt h4 {
  font-size: 1.5rem;
  font-weight: bold;
  color: #000;
  margin-bottom: 10px;
}
@media all and (max-width: 767px) {
  .class-teacher .txt h4 {
    font-size: 1.375rem;
    text-align: center;
    border-bottom: 1px solid #ccc;
    padding-bottom: 10px;
    margin-bottom: 5px;
  }
}
.class-teacher .txt p {
  font-size: 1.25rem;
  line-height: 1.8;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .class-teacher .txt p {
    font-size: 1rem;
    margin-bottom: 10px;
  }
}
.class-teacher .txt a {
  color: #6b9dc9;
  font-size: 1.125rem;
  border-bottom: 1px solid #6b9dc9;
  padding-bottom: 3px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
}
.class-teacher .txt a:hover {
  opacity: 0.8;
}

.darkGrayBg {
  background-color: #d1d1d1;
  padding: 30px 0;
  padding-bottom: 40px;
  margin-bottom: -15px;
}
@media all and (max-width: 767px) {
  .darkGrayBg {
    padding-top: 20px;
    margin-bottom: -10px;
  }
}

.darkGrayBg + .stickyArea {
  padding-top: 40px;
}

@media all and (max-width: 767px) {
  .recommendSwiper {
    overflow: initial;
  }
}
@media all and (max-width: 767px) {
  .recommendSwiper .swiper-wrapper {
    display: block;
  }
}
@media all and (max-width: 767px) {
  .recommendSwiper .swiper-slide {
    margin-bottom: 20px;
  }
  .recommendSwiper .swiper-slide:last-child {
    margin-bottom: 0;
  }
}

.recommendBx h3 {
  color: #000;
}
@media all and (max-width: 767px) {
  .recommendBx h3 {
    font-size: 1.5rem;
  }
}
.recommendBx .frame.gray {
  background-color: transparent;
}
.recommendBx .myclassli::before {
  background-color: #eee;
}
.recommendBx .swiper-pagination {
  bottom: 0px;
}
.recommendBx .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  margin: 0 6px !important;
}
.recommendBx .swiper-pagination-bullet.swiper-pagination-bullet-active {
  width: 40px;
  border-radius: 30px;
  background-color: #ff3366;
}

.recommend.swiper-pagination {
  background-color: #d1d1d1;
  position: relative;
  z-index: 1;
  padding-bottom: 40px;
  margin-bottom: -25px;
}
@media all and (max-width: 1440px) {
  .recommend.swiper-pagination {
    margin-bottom: -20px;
  }
}
@media all and (max-width: 767px) {
  .recommend.swiper-pagination {
    margin-bottom: -15px;
    display: none;
  }
}

.recommend .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  margin: 0 6px !important;
}
.recommend .swiper-pagination-bullet.swiper-pagination-bullet-active {
  width: 40px;
  border-radius: 30px;
  background-color: #ff3366;
}

.newclassBlcok .myclassli {
  padding: 0;
  background: transparent;
}
.newclassBlcok .myclassli .tag {
  display: flex;
  margin: 15px 0 5px 0;
}
@media all and (max-width: 767px) {
  .newclassBlcok .myclassli .tag {
    font-size: 0.875rem;
  }
}
.newclassBlcok .myclassli .tag span {
  color: #fff;
  background-color: #5887c3;
  border-radius: 30px;
  padding: 1px 8px;
}
.newclassBlcok .myclassli .tag span + span {
  margin-left: 5px;
}
.newclassBlcok .myclassli .price {
  color: #5887c3;
  font-size: 1.875rem;
  font-weight: bold;
  margin: 5px 0;
}
@media all and (max-width: 767px) {
  .newclassBlcok .myclassli .price {
    font-size: 1.5rem;
  }
}
.newclassBlcok .myclassli .info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid #b5b5b5;
  border-bottom: 1px solid #b5b5b5;
  padding: 8px 0;
}
.newclassBlcok .myclassli .info .teacher {
  color: #707070;
  font-weight: bold;
  font-size: 1.125rem;
}
@media all and (max-width: 1200px) {
  .newclassBlcok .myclassli .info .teacher {
    font-size: 1rem;
  }
}
.newclassBlcok .myclassli .info .time {
  color: #707070;
}
@media all and (max-width: 1200px) {
  .newclassBlcok .myclassli .info .time {
    font-size: 1rem;
  }
}
.newclassBlcok .myclassli .info .time::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  background: url(../images/time.svg) no-repeat center center/contain;
  position: relative;
  top: 4px;
  margin-right: 5px;
}
@media all and (max-width: 1200px) {
  .newclassBlcok .myclassli .info .time::before {
    width: 18px;
    height: 18px;
    top: 3px;
  }
}
.newclassBlcok .myclassli:hover {
  background: transparent;
}

.block.teacher {
  position: relative;
  top: -40px;
  padding-top: 60px;
  background-color: #e3e3e3;
}
@media all and (max-width: 767px) {
  .block.teacher {
    top: -60px;
    margin-bottom: -40px;
  }
}
.block.teacher h2 span::before {
  display: none;
}

@media all and (max-width: 767px) {
  .newsVideo .swiper-wrapper {
    flex-direction: column;
    transform: inherit !important;
  }
}
.newsVideo .swiper-slide {
  overflow: hidden;
}
.newsVideo .swiper-slide:hover img {
  transform: scale(1.1);
}
.newsVideo .swiper-slide img {
  transition: 0.4s all ease-in-out;
}
@media all and (max-width: 767px) {
  .newsVideo .swiper-slide {
    margin-bottom: 20px;
  }
  .newsVideo .swiper-slide:last-of-type {
    margin-bottom: 0;
  }
}
.newsVideo .icon-video {
  width: 80px;
  height: 56px;
  background: url(../images/video.svg) no-repeat center center/contain;
  display: block;
  margin: 0 auto;
  margin-bottom: 10px;
}
@media all and (max-width: 767px) {
  .newsVideo .icon-video {
    width: 50px;
    height: 35px;
  }
}
.newsVideo .txt {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 1.5rem;
  text-align: center;
  width: 90%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
}
@media all and (max-width: 767px) {
  .newsVideo .txt {
    font-size: 1.125rem;
  }
}
.newsVideo .imgbx {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  background-color: #000;
}
.newsVideo .imgbx iframe {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.newsVideo .imgbx img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.swiper-pagination.new {
  position: relative;
  bottom: 0;
  margin-top: 10px;
}
@media all and (max-width: 767px) {
  .swiper-pagination.new {
    margin-top: 5px;
  }
}
.swiper-pagination.new .swiper-pagination-bullet {
  border-radius: 10px;
  width: 10px;
  height: 6px;
}
.swiper-pagination.new .swiper-pagination-bullet-active {
  background: #ff3366;
  width: 35px;
}

.swiper-pagination.product {
  position: absolute;
  bottom: 0px;
  margin-top: 0px;
}
.swiper-pagination.product .swiper-pagination-bullet {
  width: 48px;
  height: 6px;
  margin: 0 15px;
  vertical-align: top;
  background: #fff;
  border-radius: 0;
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.3);
}
.appPlan-title h2 {
  display: inline-block;
  position: relative;
}
.appPlan-title h2::before {
  content: "";
  width: 40px;
  height: 1px;
  background-color: #333;
  position: absolute;
  top: 50%;
  left: -60px;
}
.appPlan-title h2::after {
  content: "";
  width: 40px;
  height: 1px;
  background-color: #333;
  position: absolute;
  top: 50%;
  right: -60px;
}

.appPlan {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .appPlan {
    flex-direction: column;
  }
}
.appPlan-item {
  width: calc((100% - 10px) / 2);
  border-radius: 15px;
  background: #fff;
  padding: 20px;
}
.appPlan-item:nth-child(even) {
  margin-right: 0;
}
@media all and (max-width: 767px) {
  .appPlan-item {
    width: 100%;
    margin-right: 0;
    padding: 15px;
  }
  .appPlan-item + .swiper-slide {
    margin-top: 20px;
  }
}
.appPlan .btnBx {
  position: relative;
  justify-content: flex-end;
}
@media all and (max-width: 767px) {
  .appPlan .btnBx {
    display: flex;
    flex-direction: row;
    gap: 10px;
  }
}
.appPlan .btnBx a {
  font-size: 1.25rem;
  font-weight: bold;
  border-radius: 5px;
}
.appPlan .btnBx a.detail {
  position: absolute;
  left: 0;
  bottom: 0;
  background: none;
  width: auto;
  color: #666;
  font-size: 1rem;
  min-width: 0;
  border: 1px solid #ddd;
}
@media all and (max-width: 767px) {
  .appPlan .btnBx a {
    font-size: 1.125rem;
    flex: 1;
  }
  .appPlan .btnBx a.detail {
    position: static;
  }
}
.appPlan h3 {
  color: #4688c8;
  font-size: 1.5rem;
  margin-bottom: 5px;
}
@media all and (max-width: 1200px) {
  .appPlan h3 {
    font-size: 1.5rem;
    margin-bottom: 5px;
  }
}
.appPlan h3 span {
  color: #8c8c8c;
  font-size: 1.125rem;
  padding-left: 5px;
  font-weight: 400;
  white-space: nowrap;
}
@media all and (max-width: 1200px) {
  .appPlan h3 span {
    font-size: 1rem;
  }
}
@media all and (max-width: 767px) {
  .appPlan h3 span {
    font-size: 0.93rem;
    padding-left: 0;
  }
}
.appPlan h3 span span {
  text-decoration: line-through;
  padding-left: 0;
}
.appPlan h4 {
  color: #1b1b1b;
  font-size: 1.5rem;
  line-height: 32px;
  font-weight: bold;
  margin-bottom: 5px;
  height: 64px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
  position: relative;
}
@media all and (max-width: 1200px) {
  .appPlan h4 {
    font-size: 1.375rem;
  }
}
@media all and (max-width: 767px) {
  .appPlan h4 {
    min-height: 0;
    font-size: 1.25rem;
    line-height: 1.6em;
    padding-bottom: 0px;
    margin-bottom: 5px;
    height: auto;
  }
}
.appPlan h4 span {
  font-weight: 400;
  color: #fff;
  padding: 1px 10px 3px 10px;
  border-radius: 30px;
  font-size: 1rem;
  line-height: 8px;
  margin-right: 10px;
  position: relative;
  top: -4px;
}
.appPlan h4 span + span {
  margin-left: -8px;
}
.appPlan h4 span.month {
  background-color: #ab71cd;
}
.appPlan h4 span.season {
  background-color: #4688c8;
}
.appPlan h4 span.year {
  background-color: #3b3f8a;
}
@media all and (max-width: 767px) {
  .appPlan h4 span {
    font-size: 1rem;
    margin-right: 5px;
    top: 0;
  }
}
.appPlan ul {
  border-top: 1px solid #bfbfbf;
  padding-top: 15px;
  margin-top: 15px;
}
.appPlan li {
  padding-left: 18px;
  color: #1b1b1b;
  font-size: 1.125rem;
  position: relative;
}
.appPlan li::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: #4f8dca;
  position: absolute;
  left: 2px;
  top: 15px;
}
@media all and (max-width: 767px) {
  .appPlan li::before {
    top: 10px;
  }
}
@media all and (max-width: 1200px) {
  .appPlan li {
    font-size: 1.125rem;
  }
}
@media all and (max-width: 767px) {
  .appPlan li {
    font-size: 1rem;
  }
}

.main.gray {
  background-color: #f5f5f5;
}

.proFn-list {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.proFn-list li {
  position: relative;
  background-color: #fff;
  border-radius: 10px;
  padding: 20px;
  width: 31.33%;
  margin-right: 3%;
  margin-bottom: 30px;
  border: 1px solid transparent;
  transition: 0.3s all ease-in-out;
  display: flex;
  flex-direction: column;
}
.proFn-list li:hover {
  border-color: #5887c3;
}
.proFn-list li:nth-child(3n) {
  margin-right: 0;
}
@media all and (max-width: 1200px) {
  .proFn-list li {
    width: 48.5%;
  }
  .proFn-list li:nth-child(3n) {
    margin-right: 3%;
  }
  .proFn-list li:nth-child(2n) {
    margin-right: 0;
  }
}
@media all and (max-width: 767px) {
  .proFn-list li {
    width: 100%;
    margin-right: 0;
    margin-bottom: 20px;
    padding: 15px;
  }
  .proFn-list li h5 {
    font-size: 1.5rem;
    text-align: left;
  }
}
.proFn-list .bt-btn {
  display: flex;
  margin-top: 10px;
}
.proFn-list .bt-btn a {
  background-color: #5887c3;
  color: #fff;
  font-size: 1.25rem;
  padding: 1px 15px;
  border-radius: 50px;
  min-width: 120px;
  text-align: center;
  transition: 0.2s all ease-in-out;
}
.proFn-list .bt-btn a:hover {
  background-color: #79a6e0;
}
.proFn-list .bt-btn a + a {
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .proFn-list .bt-btn a {
    width: 50%;
    font-size: 1.125rem;
    padding: 3px 15px;
  }
}

.tab.proFn {
  position: relative;
  top: 8px;
}

.proFn-listBx h2 {
  margin-bottom: 15px;
}
@media all and (max-width: 767px) {
  .proFn-listBx h2 {
    margin-bottom: -15px;
  }
}

.proFn-listBx + .proFn-listBx {
  margin-top: -25px;
}
@media all and (max-width: 767px) {
  .proFn-listBx + .proFn-listBx {
    margin-top: -15px;
  }
}

.proFn-listBx:last-of-type {
  margin-bottom: -40px;
}
@media all and (max-width: 767px) {
  .proFn-listBx:last-of-type {
    margin-bottom: -20px;
  }
}

.lightGray.box {
  background-color: #f5f5f5;
  padding: 30px 0;
  margin-bottom: -15px;
  min-height: calc(100vh - 538px);
}
@media all and (max-width: 767px) {
  .lightGray.box {
    padding: 20px 0;
  }
}

.disCount-fm + .paginationArea {
  margin-top: 40px;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .disCount-fm + .paginationArea {
    margin-top: 30px;
    margin-bottom: 15px;
  }
}

.disCount-fm {
  display: block;
}
.disCount-fm .input-fm {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 20px;
  min-height: 50px;
  line-height: 50px;
  font-size: 1.125rem;
}
.disCount-fm .input-fm input::-webkit-input-placeholder {
  color: #999999;
  font-size: 1.125rem;
  font-weight: 400;
}
@media all and (max-width: 767px) {
  .disCount-fm .input-fm input::-webkit-input-placeholder {
    font-size: 1.125rem;
  }
}
.disCount-fm .btn {
  font-size: 1.5rem;
  padding: 5px 20px;
  min-width: 250px;
  border-radius: 50px;
  background-color: #ff0062;
  color: #fff;
  text-align: center;
  display: inline-block;
  margin-bottom: 15px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
}
.disCount-fm .btn:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .disCount-fm .btn {
    min-width: 100%;
    font-size: 1.25rem;
    padding: 3px 20px;
  }
}
.disCount-fm h3 {
  font-size: 1.5rem;
  color: #000;
  margin-bottom: 15px;
  line-height: 1.7;
}
@media all and (max-width: 767px) {
  .disCount-fm h3 {
    font-size: 1.375rem;
  }
}
.disCount-fm h3 .mark {
  font-weight: bold;
  border-bottom: 1px solid #000;
}
.disCount-fm .tab {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 40px;
}
@media all and (max-width: 767px) {
  .disCount-fm .tab {
    margin-bottom: 20px;
  }
}
.disCount-fm .tab .tab-item {
  border: 1px solid #a6a6a6;
  color: #a6a6a6;
  padding: 0px 20px;
  font-size: 1.25rem;
  border-radius: 30px;
  min-width: auto;
  white-space: nowrap;
}
@media all and (max-width: 767px) {
  .disCount-fm .tab .tab-item {
    font-size: 1.125rem;
  }
}
.disCount-fm .tab .tab-item.on {
  background-color: #5887c3;
  border-color: #5887c3;
  color: #fff;
}
.disCount-fm .tab .tab-item.on:hover {
  color: #fff;
}
.disCount-fm .tab .tab-item:hover {
  color: #5887c3;
  border-color: #5887c3;
}
.disCount-fm .tab .tab-item + .tab-item {
  margin-left: 20px;
}
@media all and (max-width: 767px) {
  .disCount-fm .tab .tab-item + .tab-item {
    margin-left: 10px;
  }
}
.disCount-fm .discount-card {
  border-radius: 10px;
  padding: 25px;
  background-color: #fff;
  font-size: 1.125rem;
  color: #1b1b1b;
  display: flex;
}
.disCount-fm .discount-card + .discount-card {
  margin-top: 25px;
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card + .discount-card {
    margin-top: 20px;
  }
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card {
    padding: 15px;
    flex-direction: column;
    align-items: center;
  }
}
.disCount-fm .discount-card h3 {
  font-weight: bold;
  padding-right: 250px;
  line-height: 1.4;
}
@media all and (max-width: 1200px) {
  .disCount-fm .discount-card h3 {
    padding-right: 0;
  }
}
.disCount-fm .discount-card .price {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: linear-gradient(to bottom, #7cc7e0, #5789c4, #8b4b96, #9e4c94);
  margin-right: 30px;
  flex: 0 0 auto;
  position: relative;
}
.disCount-fm .discount-card .price.Used {
  background: #a6a6a6;
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card .price {
    margin-bottom: 20px;
    margin-right: 0;
  }
}
.disCount-fm .discount-card .price span {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 1.875rem;
  font-weight: bold;
  white-space: nowrap;
}
.disCount-fm .discount-card .txt {
  width: 100%;
  position: relative;
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card .txt p + p {
    margin-top: 5px;
  }
}
.disCount-fm .discount-card .order {
  position: absolute;
  right: 0;
  top: 0;
  background-color: #e5e5e5;
  border: 2px dotted #c3c3c3;
  border-radius: 10px;
  padding: 3px 15px;
  font-size: 1.25rem;
}
@media all and (max-width: 1200px) {
  .disCount-fm .discount-card .order {
    position: relative;
    margin-bottom: 10px;
  }
}
.disCount-fm .discount-card .order::before {
  content: "序號 ";
}
.disCount-fm .discount-card .order .copy-icon {
  width: 22px;
  height: 22px;
  background: url(../images/copy-icon.svg) no-repeat center center/contain;
  display: inline-block;
  position: relative;
  margin-left: 12px;
  top: 2px;
}
@media all and (max-width: 1200px) {
  .disCount-fm .discount-card .order .copy-icon {
    position: absolute;
    right: 10px;
    top: 10px;
  }
}
.disCount-fm .discount-card .colorRed {
  color: #ff0062;
}
.disCount-fm .discount-card .colorBlue {
  color: #5887c3;
}
.disCount-fm .discount-card hr {
  margin: 15px 0;
}
.disCount-fm .discount-card .forwho {
  margin-bottom: 20px;
}
@media all and (max-width: 1200px) {
  .disCount-fm .discount-card .forwho {
    flex-direction: column;
  }
}
.disCount-fm .discount-card .forwho p {
  font-weight: 500;
  margin-right: 5px;
  white-space: nowrap;
}
.disCount-fm .discount-card .forwho ul {
  width: 100%;
}
.disCount-fm .discount-card .forwho li {
  padding-left: 25px;
  position: relative;
}
.disCount-fm .discount-card .forwho li + li {
  margin-top: 5px;
}
.disCount-fm .discount-card .forwho li::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #5887c3;
}
.disCount-fm .discount-card .forwho .table-sy1 td {
  padding: 15px 0;
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card .forwho .table-sy1 td {
    padding: 10px 0 0;
    margin-left: 0px;
  }
  .disCount-fm .discount-card .forwho .table-sy1 td::before {
    display: none;
  }
  .disCount-fm .discount-card .forwho .table-sy1 td.ca-nm {
    display: flex;
  }
  .disCount-fm .discount-card .forwho .table-sy1 td.ca-nm .imgbx {
    width: 150px;
    margin-bottom: 0;
  }
  .disCount-fm .discount-card .forwho .table-sy1 td.ca-nm .txt {
    padding-left: 10px;
    width: auto;
    flex: 1;
  }
}
@media all and (max-width: 767px) {
  .disCount-fm .discount-card .forwho .table-sy1 tr {
    margin-bottom: 0px;
  }
}
.disCount-fm .no-data {
  text-align: center;
  padding-top: 25px;
}
@media all and (max-width: 767px) {
  .disCount-fm .no-data {
    padding-bottom: 20px;
  }
}
.disCount-fm .no-data .colorRed {
  color: #ff0062;
}
.disCount-fm .no-data .imgbx {
  margin: 0 auto;
  margin-bottom: 20px;
  width: 100px;
}
.disCount-fm .no-data h3 {
  font-size: 1.875rem;
  margin-bottom: 10px;
  line-height: 1.4;
}
@media all and (max-width: 767px) {
  .disCount-fm .no-data h3 {
    font-size: 1.5rem;
  }
}
.disCount-fm .no-data p {
  font-size: 1.5rem;
  line-height: 1.4;
}
@media all and (max-width: 767px) {
  .disCount-fm .no-data p {
    font-size: 1.25rem;
  }
}

.liveStream_block .loading .lds-spinner {
  width: 80px;
  height: 80px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.liveStream_block .loading .lds-spinner div {
  transform-origin: 40px 40px;
  -webkit-animation: lds-spinner 1.2s linear infinite;
  animation: lds-spinner 1.2s linear infinite;
}
.liveStream_block .loading .lds-spinner div:after {
  content: " ";
  display: block;
  position: absolute;
  top: 3px;
  left: 37px;
  width: 6px;
  height: 18px;
  border-radius: 20%;
  background: #333;
}
.liveStream_block .loading .lds-spinner div:nth-child(1) {
  transform: rotate(0deg);
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}
.liveStream_block .loading .lds-spinner div:nth-child(2) {
  transform: rotate(30deg);
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
}
.liveStream_block .loading .lds-spinner div:nth-child(3) {
  transform: rotate(60deg);
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}
.liveStream_block .loading .lds-spinner div:nth-child(4) {
  transform: rotate(90deg);
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}
.liveStream_block .loading .lds-spinner div:nth-child(5) {
  transform: rotate(120deg);
  -webkit-animation-delay: -0.7s;
  animation-delay: -0.7s;
}
.liveStream_block .loading .lds-spinner div:nth-child(6) {
  transform: rotate(150deg);
  -webkit-animation-delay: -0.6s;
  animation-delay: -0.6s;
}
.liveStream_block .loading .lds-spinner div:nth-child(7) {
  transform: rotate(180deg);
  -webkit-animation-delay: -0.5s;
  animation-delay: -0.5s;
}
.liveStream_block .loading .lds-spinner div:nth-child(8) {
  transform: rotate(210deg);
  -webkit-animation-delay: -0.4s;
  animation-delay: -0.4s;
}
.liveStream_block .loading .lds-spinner div:nth-child(9) {
  transform: rotate(240deg);
  -webkit-animation-delay: -0.3s;
  animation-delay: -0.3s;
}
.liveStream_block .loading .lds-spinner div:nth-child(10) {
  transform: rotate(270deg);
  -webkit-animation-delay: -0.2s;
  animation-delay: -0.2s;
}
.liveStream_block .loading .lds-spinner div:nth-child(11) {
  transform: rotate(300deg);
  -webkit-animation-delay: -0.1s;
  animation-delay: -0.1s;
}
.liveStream_block .loading .lds-spinner div:nth-child(12) {
  transform: rotate(330deg);
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}
@-webkit-keyframes lds-spinner {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes lds-spinner {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.joinChat {
  display: block;
  font-size: 1.5rem;
  background-color: #ff3366;
  padding: 8px 35px;
  border-radius: 40px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
  color: #fff;
  border: 1px solid #ff3366;
  text-align: center;
  max-width: 170px;
  margin: 0 auto;
  white-space: nowrap;
  margin-top: 20px;
}
@media all and (max-width: 767px) {
  .joinChat {
    font-size: 1.125rem;
    padding: 4px 20px;
    max-width: 120px;
    font-weight: 500;
  }
}

.main.onlychat {
  padding-bottom: 0;
  padding-top: 0;
}
.main.onlychat .darkGrayBg {
  margin-bottom: 0;
}
@media all and (max-width: 767px) {
  .main.onlychat .liveStream_block {
    margin-top: 0;
    padding-top: 15px;
  }
}

.liveStream_block .full .message-area {
  max-height: calc(100vh - 90px);
  height: calc(100vh - 90px);
}
@media all and (max-width: 767px) {
  .liveStream_block .full .message-area {
    max-height: calc(100vh - 60px);
    height: calc(100vh - 60px);
  }
}

.liveStream_block {
  display: block;
  padding: 45px 0;
  background-color: #222;
  margin-top: -20px;
}
.liveStream_block .loading {
  background-color: #fff;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}
@media all and (max-width: 1440px) {
  .liveStream_block {
    margin-top: -15px;
  }
}
.liveStream_block .class-vdBx-video {
  width: 100%;
}
.liveStream_block .class-vdBx-list {
  max-width: 500px;
  flex: 0 0 auto;
}
.liveStream_block .class-vdBx-list.full {
  max-width: 100%;
  width: 100%;
  margin-top: 0px;
}
@media all and (max-width: 1200px) {
  .liveStream_block .class-vdBx-list {
    max-width: 100%;
  }
}
.liveStream_block .in {
  max-width: 100%;
}
.liveStream_block .in.maxW {
  max-width: 1320px;
}
.liveStream_block .onair {
  position: absolute;
  left: 15px;
  top: 10px;
  color: #fe0000;
  font-size: 1rem;
  z-index: 2;
  font-weight: bold;
  letter-spacing: 0;
}
@media all and (max-width: 767px) {
  .liveStream_block .onair {
    top: 5px;
    font-size: 0.93rem;
    left: 10px;
  }
}
.liveStream_block .onair::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #fe0000;
  vertical-align: middle;
  margin-right: 5px;
  position: relative;
  top: -1.6px;
}
@media all and (max-width: 767px) {
  .liveStream_block .onair::before {
    width: 10px;
    height: 10px;
    top: -1.6px;
  }
}
.liveStream_block .view {
  padding: 2px 10px 2px 50px;
  background-color: rgba(0, 0, 0, 0.3);
  color: #fff;
  position: relative;
  z-index: 10;
  position: absolute;
  right: 15px;
  top: 10px;
  border-radius: 5px;
}
.liveStream_block .view::before {
  content: "";
  position: absolute;
  left: 10px;
  top: 6px;
  width: 18px;
  height: 18px;
  background: url(../images/live_view.svg) no-repeat center center/contain;
}
@media all and (max-width: 767px) {
  .liveStream_block .view {
    font-size: 0.875rem;
    padding: 2px 5px 2px 25px;
    right: 8px;
    top: 5px;
  }
  .liveStream_block .view::before {
    width: 14px;
    height: 14px;
    left: 5px;
    top: 7px;
  }
}
@media all and (max-width: 767px) {
  .liveStream_block {
    padding: 15px 0;
  }
}
@media all and (max-width: 767px) {
  .liveStream_block .class-vdBx {
    margin-right: 0px;
    margin-left: 0px;
    margin-bottom: 0px;
  }
}
.liveStream_block .live-txtbg {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.liveStream_block .live-txtbg::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #606060;
  opacity: 0.67;
  z-index: 2;
}
.liveStream_block .live-txtbg img {
  -webkit-filter: blur(3px);
  filter: blur(3px);
}
.liveStream_block .live-txtbg.live-Now::before {
  display: none;
}
.liveStream_block .live-txtbg.live-Now img {
  -webkit-filter: initial;
  filter: initial;
}
.liveStream_block .txt {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  z-index: 5;
}
.liveStream_block .txt .bluetxt {
  color: #a5cdff;
}
.liveStream_block .txt h3 {
  color: #fff;
  font-size: 2.25rem;
  white-space: nowrap;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt h3 {
    font-size: 1.25rem;
  }
}
.liveStream_block .txt h4 {
  font-size: 1.875rem;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt h4 {
    font-size: 1.125rem;
    white-space: nowrap;
  }
}
.liveStream_block .txt h4 + p {
  margin-top: 10px;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt h4 + p {
    margin-top: 5px;
  }
}
.liveStream_block .txt p {
  font-size: 1.5rem;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt p {
    font-size: 1rem;
  }
}
.liveStream_block .txt .buy {
  display: inline-block;
  font-size: 1.5rem;
  background-color: #ff3366;
  padding: 8px 35px;
  border-radius: 40px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
  color: #fff;
  border: 1px solid #ff3366;
  text-align: center;
  margin: 0 auto;
  white-space: nowrap;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt .buy {
    font-size: 1.125rem;
    padding: 4px 20px;
    margin: 0 0 10px;
    font-weight: 500;
  }
}
.liveStream_block .txt .space {
  margin-bottom: 40px;
  display: block;
}
@media all and (max-width: 767px) {
  .liveStream_block .txt .space {
    margin-bottom: 20px;
  }
}
.liveStream_block .class-vdBx-list {
  z-index: 4;
  border-radius: 2px;
  background-color: #fff;
  position: relative;
}
.liveStream_block .class-vdBx-list .cover-txt {
  position: absolute;
  left: 0;
  top: 40px;
  background-color: #fff;
  width: 100%;
  height: 100%;
  text-align: center;
  padding: 0px;
  z-index: 2;
}
@media all and (max-width: 767px) {
  .liveStream_block .class-vdBx-list .cover-txt {
    max-height: 250px;
    min-height: 250px;
  }
}
.liveStream_block .class-vdBx-list .cover-txt p {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  color: #ff3366;
  text-align: center;
  font-size: 1.5rem;
  white-space: nowrap;
  padding-top: 70px;
  background: url(../images/mesAlert-icon.svg) no-repeat center top;
  background-size: 60px auto;
}
@media all and (max-width: 767px) {
  .liveStream_block .class-vdBx-list .cover-txt p {
    font-size: 1.125rem;
    background-size: 50px auto;
    padding-top: 60px;
  }
}
.liveStream_block .top-tit {
  padding: 3px 10px 3px 40px;
  border-bottom: 1px solid #e5e5e5;
  background: url(../images/message-icon.svg) no-repeat left 15px top 10px;
  background-size: 20px auto;
  font-size: 1.125rem;
}
.liveStream_block .message-area {
  display: flex;
  flex-direction: column;
}
@media all and (max-width: 767px) {
  .liveStream_block .message-area {
    min-height: 310px;
    max-height: 310px;
  }
}
.liveStream_block .message-area .message-bx {
  flex-grow: 1;
  flex-shrink: 1;
  overflow-y: hidden;
}
@media all and (max-width: 767px) {
  .liveStream_block .message-area .message-bx {
    overflow-y: scroll;
  }
}
.liveStream_block .message-area .bt-status {
  flex: 0 0 auto;
  max-height: 150px;
  border-radius: 8px;
  background-color: #d9d9d9;
  width: calc(100% - 30px);
  padding: 6px 45px 6px 10px;
  resize: none;
  margin: 10px 15px;
  box-sizing: border-box;
  text-align: left;
}
.liveStream_block .message-area .bt-status:disabled {
  color: transparent;
}
@media all and (max-width: 767px) {
  .liveStream_block .message-area .bt-status {
    max-height: 130px;
  }
}
.liveStream_block .message-bx {
  position: relative;
  padding-top: 10px;
}
.liveStream_block .message-bx .mCSB_container {
  margin-right: 0;
}
.liveStream_block .message-bx .mCSB_scrollTools {
  right: 5px;
}
.liveStream_block .message-item {
  display: flex;
  padding: 13px 15px;
}
.liveStream_block .message-item .head-img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  margin-right: 15px;
  flex: 0 0 auto;
  overflow: hidden;
  position: relative;
  top: 2px;
}
.liveStream_block .message-item .head-img img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.liveStream_block .message-item .message {
  width: 100%;
  margin-top: -3px;
}
.liveStream_block .message-item .message .name {
  font-size: 0.875rem;
  color: #444;
  line-height: 1.2;
  margin-bottom: 3px;
}
.liveStream_block .message-item .message .name span {
  font-size: 0.875rem;
  color: #737373;
  margin-left: 3px;
}
.liveStream_block .message-item .message p {
  font-size: 1rem;
  margin-top: 2px;
  line-height: 1.2;
  word-break: break-all;
  color: #000;
}
@media all and (max-width: 1200px) {
  .liveStream_block .message-item .message p {
    font-size: 1rem;
  }
}
.liveStream_block .message-item.user {
  flex-direction: row-reverse;
  background: #f3f3f3;
  padding: 10px 15px;
}
.liveStream_block .message-item.user .head-img {
  margin-left: 15px;
  margin-right: 0;
}
.liveStream_block .message-item.user .message {
  text-align: right;
}
.liveStream_block .message-item.user .message .name {
  color: #748fc2;
}
.liveStream_block .message-item.user .message .name span {
  color: #737373;
}
.liveStream_block .message-item.user .message p {
  color: #033086;
  text-align: left;
  display: inline-block;
  line-height: 1.7;
}
.liveStream_block .message-item .message-tool {
  display: inline-block;
  position: relative;
  vertical-align: middle;
}
.liveStream_block .message-item .message-tool_bt {
  cursor: pointer;
  width: 25px;
  height: 25px;
  background: url(../images/icon_mess_setting.svg) no-repeat center center/20px auto;
}
.liveStream_block .message-item .message-tool_list {
  position: absolute;
  top: 30px;
  left: -100px;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.3);
}
.liveStream_block .message-item .message-tool_list li {
  border-bottom: 1px solid #ddd;
}
.liveStream_block .message-item .message-tool_list li:last-child {
  border: none;
}
.liveStream_block .message-item .message-tool_list a {
  display: block;
  text-align: center;
  padding: 10px;
  font-size: 0.875rem;
  line-height: 1.4em;
  white-space: nowrap;
}
.liveStream_block .message-item .message-tool_list a:hover {
  color: #ff3366;
}
.liveStream_block .bt-status {
  padding: 12px;
  position: relative;
}
.liveStream_block .bt-status.disable input,
.liveStream_block .bt-status.disable textarea {
  pointer-events: none;
}
.liveStream_block .bt-status.disable input::-webkit-input-placeholder,
.liveStream_block .bt-status.disable textarea::-webkit-input-placeholder {
  color: transparent;
}
.liveStream_block .bt-status.disable .send {
  cursor: auto;
}
.liveStream_block .bt-status.disable .send:hover {
  opacity: 1;
}
.liveStream_block .bt-status .cover-txt {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  background-color: #fff;
  width: 100%;
  height: 100%;
}
.liveStream_block .bt-status .cover-txt p {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  color: #0d0d0d;
}
.liveStream_block .bt-status textarea {
  min-height: 60px;
  border-radius: 8px;
  background-color: #d9d9d9;
  width: 100%;
  padding: 6px 45px 6px 10px;
  resize: none;
}

.send {
  width: 25px;
  height: 25px;
  background: url(../images/send.svg) no-repeat center center/contain;
  position: absolute;
  bottom: 15px;
  right: 25px;
}
.send:hover {
  opacity: 0.8;
}

.live-Textbook {
  border: 1px solid #7dc7df;
  border-radius: 15px;
  padding: 10px 20px;
  counter-reset: num;
}
@media all and (max-width: 767px) {
  .live-Textbook {
    padding-top: 5px;
    padding-bottom: 10px;
    padding-left: 15px;
    padding-right: 15px;
  }
}

.live-Textbook-item {
  position: relative;
  padding: 12px;
  border-bottom: 1px solid #cccccc;
  padding-left: 40px;
  font-size: 1.25rem;
  display: flex;
  align-items: flex-start;
}
@media all and (max-width: 767px) {
  .live-Textbook-item {
    flex-wrap: wrap;
    font-size: 1.125rem;
  }
}
.live-Textbook-item:hover {
  color: #5887c3;
}

.live-Textbook-item:last-of-type {
  border-bottom: none;
}

.live-Textbook-item::before {
  counter-increment: num;
  content: counter(num) ". ";
  display: inline-block;
  position: absolute;
  left: 20px;
  top: 12px;
}

.live-Textbook-item p {
  display: inline-block;
}
@media all and (max-width: 767px) {
  .live-Textbook-item p {
    margin-bottom: 15px;
  }
}

.live-Textbook-item::after {
  content: "";
  position: absolute;
  left: 0;
  top: 25px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}

.live-Textbook-item p {
  width: 100%;
}

.live-Textbook-item .link {
  width: 240px;
  flex: 0 0 auto;
  display: flex;
}
@media all and (max-width: 767px) {
  .live-Textbook-item .link {
    width: 100%;
  }
}

.live-Textbook-item .link a {
  color: #fff;
  font-size: 1.25rem;
  padding: 3px 15px;
  border-radius: 50px;
  background-color: #5887c3;
  width: 100%;
  display: block;
  white-space: nowrap;
  text-align: center;
}
.live-Textbook-item .link a:hover {
  opacity: 0.8;
}
@media all and (max-width: 767px) {
  .live-Textbook-item .link a {
    font-size: 1.125rem;
    padding: 2px 15px;
  }
}

.live-Textbook-item .link a.test {
  background-color: #bb83ba;
}

.live-Textbook-item .link a + a {
  margin-left: 15px;
}

.download-textbooks {
  max-height: 70vh;
  overflow-y: auto;
}
.download-textbooks li {
  padding: 10px 40px 10px 10px;
  position: relative;
  font-size: 1.125rem;
  color: #333;
}
@media all and (max-width: 767px) {
  .download-textbooks li {
    font-size: 1rem;
  }
}
.download-textbooks li:hover {
  opacity: 0.8;
  color: #5887c3;
}
.download-textbooks li::after {
  content: "";
  width: 30px;
  height: 30px;
  position: absolute;
  right: 0px;
  top: 10px;
  background: url(../images/download.svg) no-repeat center center/contain;
}
.download-textbooks li.pdf::after {
  background: url(../images/download_pdf.svg) no-repeat center center/contain;
}
.download-textbooks li.xls::after {
  background: url(../images/download_excel.svg) no-repeat center center/contain;
}
.download-textbooks li::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #5887c3;
  display: inline-block;
  margin-right: 10px;
  position: relative;
  top: -1px;
}
.download-textbooks li + li {
  border-top: 2px dotted #c7c7c7;
}

.testPage .header-logo,
.testPage h2 {
  margin-bottom: 25px;
  position: relative;
}
.testPage .header-logo.testit::before,
.testPage h2.testit::before {
  content: "";
  position: absolute;
  background-color: #3d88b1;
  width: 45px;
  height: 2px;
  left: 0;
  bottom: -8px;
  display: block;
}
@media all and (max-width: 767px) {
  .testPage .header-logo,
  .testPage h2 {
    font-size: 1.375rem;
  }
}
.testPage .question {
  counter-reset: nums;
}
.testPage .question-item {
  position: relative;
}
.testPage .question-item .ans {
  font-size: 1.25rem;
  color: #ff3366;
  position: absolute;
  right: 20px;
  top: 9px;
}
.testPage .question-item .ans::before {
  content: "正確答案:";
}
@media all and (max-width: 1200px) {
  .testPage .question-item .ans {
    text-align: right;
    position: relative;
    left: 0;
    right: auto;
    top: auto;
    margin-top: -20px;
    margin-bottom: 40px;
    left: auto;
  }
}
@media all and (max-width: 767px) {
  .testPage .question-item .ans {
    font-size: 1.125rem;
    margin-bottom: 20px;
  }
}
.testPage .question-item h4 {
  font-size: 1.25rem;
  padding: 12px 20px 12px 40px;
  display: block;
  background-color: #f3f3f3;
}
@media all and (max-width: 767px) {
  .testPage .question-item h4 {
    font-size: 1.125rem;
    padding: 10px 10px 10px 30px;
  }
}
.testPage .question-item h4::before {
  counter-increment: nums;
  content: counter(nums) ". ";
  position: absolute;
  left: 20px;
  top: 12px;
}
@media all and (max-width: 767px) {
  .testPage .question-item h4::before {
    left: 12px;
    top: 10px;
  }
}
.testPage .radio-list {
  padding: 10px 20px 20px 45px;
  max-width: 70%;
}
@media all and (max-width: 1200px) {
  .testPage .radio-list {
    max-width: 100%;
  }
}
@media all and (max-width: 767px) {
  .testPage .radio-list {
    padding-left: 30px;
  }
}
.testPage .radio-list-item {
  display: inline-block;
  min-width: 300px;
  font-size: 1.25rem;
  vertical-align: text-top;
  color: #555;
  margin-bottom: 10px;
}
@media all and (max-width: 1200px) {
  .testPage .radio-list-item {
    width: 48%;
  }
}
@media all and (max-width: 767px) {
  .testPage .radio-list-item {
    font-size: 1.125rem;
    width: 100%;
  }
}
.testPage input[type=radio] ~ label .icon {
  top: 7px;
}
@media all and (max-width: 767px) {
  .testPage input[type=radio] ~ label .icon {
    top: 5px;
  }
}
.testPage input[type=radio]:checked ~ label .icon::before {
  width: 12px;
  height: 12px;
  background-color: #353535;
}
.testPage .result {
  background-color: #fff2f5;
  padding: 12px 20px;
  font-size: 1.5rem;
  display: flex;
  margin-top: 40px;
  margin-bottom: 30px;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .testPage .result {
    padding: 10px 15px;
    font-size: 1.25rem;
  }
}
.testPage .result p + p {
  margin-left: 15px;
}
.testPage .result .correct {
  color: #ff3366;
}
.testPage .btn {
  font-size: 1.5rem;
  background-color: #ff3366;
  padding: 8px 35px;
  border-radius: 40px;
  font-weight: bold;
  transition: 0.2s all ease-in-out;
  color: #fff;
  border: 1px solid #ff3366;
  text-align: center;
  display: inline-block;
  min-width: 180px;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .testPage .btn {
    font-size: 1.25rem;
    padding: 5px 20px;
  }
}

#videoFileProgressBar {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

body.fixed {
  overflow-y: hidden;
}

@media all and (max-width: 767px) {
  .block.searchH {
    min-height: calc(100vh - 562px);
  }
}

.searchResult-bx {
  max-width: 1000px;
  padding: 15px 0;
  margin: 0 auto;
  padding-bottom: 60px;
  padding-top: 30px;
}
@media all and (max-width: 767px) {
  .searchResult-bx {
    padding-bottom: 30px;
    padding-top: 20px;
  }
}
.searchResult-bx .keyword li {
  display: inline-block;
  margin-bottom: 10px;
  margin-right: 10px;
}
@media all and (max-width: 767px) {
  .searchResult-bx .keyword li {
    margin-right: 5px;
  }
}
.searchResult-bx .keyword li:hover a {
  background-color: #3e87bf;
}
.searchResult-bx .keyword li a {
  background-color: #454545;
  color: #fff;
  padding: 3px 10px;
  border-radius: 5px;
  font-size: 1.25rem;
}
@media all and (max-width: 767px) {
  .searchResult-bx .keyword li a {
    font-size: 1.125rem;
  }
}
.searchResult-bx input {
  border-color: #757575;
  height: 50px;
  line-height: 50px;
  font-size: 1.375rem;
  color: #000;
}
@media all and (max-width: 767px) {
  .searchResult-bx input {
    font-size: 1.25rem;
  }
}
.searchResult-bx .input {
  position: relative;
  margin-bottom: 20px;
}
.searchResult-bx .input a {
  position: absolute;
  right: 15px;
  top: 12px;
  width: 25px;
  height: 25px;
  background: url(../images/search_black.svg) no-repeat center center/contain;
}
.searchResult-bx .input a:hover {
  opacity: 0.8;
}
.searchResult-bx input::-moz-placeholder {
  font-size: 1.375rem;
}
.searchResult-bx input:-ms-input-placeholder {
  font-size: 1.375rem;
}
.searchResult-bx input:-moz-placeholder {
  font-size: 1.375rem;
}
.searchResult-bx input::-webkit-input-placeholder {
  font-size: 1.375rem;
}
@media all and (max-width: 767px) {
  .searchResult-bx input::-moz-placeholder {
    font-size: 1.25rem;
  }
  .searchResult-bx input:-ms-input-placeholder {
    font-size: 1.25rem;
  }
  .searchResult-bx input:-moz-placeholder {
    font-size: 1.25rem;
  }
  .searchResult-bx input::-webkit-input-placeholder {
    font-size: 1.25rem;
  }
}

.search-noinfo {
  text-align: center;
  margin-top: 30px;
}
@media all and (max-width: 767px) {
  .search-noinfo {
    margin-top: 0px;
  }
}
.search-noinfo .imgbx {
  width: 120px;
  margin: 0 auto;
  padding: 31px 0;
}
@media all and (max-width: 767px) {
  .search-noinfo .imgbx {
    padding: 15px 0;
    width: 100px;
  }
}
.search-noinfo p {
  color: #000;
  font-size: 1.5rem;
  font-weight: 500;
}
@media all and (max-width: 767px) {
  .search-noinfo p {
    font-size: 1.25rem;
    margin-bottom: 15px;
  }
}

.popupVideo .video-popup {
  width: 100dvw;
  height: 100dvh;
  background-color: #333;
  position: fixed;
  z-index: 999;
  top: 0;
  left: 0;
}
.popupVideo .iframe-wrapper {
  width: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.popupVideo .iframe-wrapper.landscape {
  width: 177.7777777778dvh;
  height: 100%;
}
.popupVideo .iframe-size {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
}
.popupVideo .iframe-size iframe {
  position: absolute;
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
  height: 100%;
}

.tit-g .total {
  position: absolute;
  right: 0;
  font-size: 1.25rem;
  top: 2px;
}

.tooltip_area {
  cursor: pointer;
}

.total .colorblue {
  margin: 0 3px;
  color: #5887c3;
}

.tit-g .total:hover .tooltip-con {
  opacity: 1;
}

.tooltip-icon {
  width: 26px;
  height: 26px;
  background: url(../images/tooltip-icon.svg) no-repeat center center;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  top: -2px;
}

.tooltip-con {
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translateY(105%);
  background-color: #999;
  color: #fff;
  width: 300px;
  font-size: 1rem;
  padding: 10px;
  border-radius: 5px;
  line-height: 1.4;
  opacity: 0;
  z-index: 2;
  transition: 0.2s opacity ease-in-out;
}
@media all and (max-width: 767px) {
  .tooltip-con {
    font-size: 0.93rem;
  }
}

.scrollbx-report {
  background-color: #e7eaed;
  border-radius: 15px;
  padding: 25px;
  max-height: 367px;
}
@media all and (max-width: 1200px) {
  .scrollbx-report {
    padding: 20px;
  }
}
@media all and (max-width: 767px) {
  .scrollbx-report {
    padding: 15px;
    overflow-y: scroll;
    border-radius: 0px;
    max-height: initial;
    margin-bottom: 25px;
  }
}

.report {
  font-size: 1.25rem;
}
@media all and (max-width: 1200px) {
  .report {
    font-size: 1.125rem;
  }
}
@media all and (max-width: 767px) {
  .report {
    font-size: 1rem;
  }
}

.report.lock li::before {
  content: "";
  display: inline-block;
  position: absolute;
  border-radius: 0;
  left: 13px;
  top: 20px;
  width: 20px;
  height: 20px;
  background: url(../images/class-lock.svg) no-repeat center center/contain;
}
@media all and (max-width: 767px) {
  .report.lock li::before {
    width: 16px;
    left: 10px;
    top: 15px;
  }
}

.report.lock li.try::before {
  content: "試看";
  background: none;
  background-color: #ff3366;
  color: #fff;
  font-size: 1rem;
  border-radius: 20px;
  padding: 5px 5px;
  white-space: nowrap;
  width: 40px;
  line-height: 1;
  text-align: center;
  top: 15px;
  left: 0;
}
@media all and (max-width: 767px) {
  .report.lock li.try::before {
    padding: 2px 5px;
    line-height: 1.4;
    border-radius: 20px;
    font-size: 0.8rem;
    width: auto;
    top: 13px;
  }
}

.report.lock li a {
  background-color: #afb3b9;
  color: #e9e9e9;
  pointer-events: none;
}

.report.lock li.try a {
  background-color: #5887c3;
  color: #fff;
  pointer-events: initial;
}

.report.lock li {
  padding: 12px 100px 12px 60px;
}
@media all and (max-width: 767px) {
  .report.lock li {
    padding-left: 45px;
    padding-right: 60px;
  }
}

.report li {
  padding: 12px 100px 12px 30px;
  position: relative;
}

.report li p {
  line-height: 1.4;
}

.report li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 23px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}

.report li + li {
  border-top: 1px solid #cccccc;
}

.report li a {
  position: absolute;
  right: 0;
  top: 8px;
  background-color: #5887c3;
  color: #fff;
  padding: 1px 15px;
  border-radius: 30px;
  min-width: 100px;
  text-align: center;
  transition: 0.2s opacity ease-in-out;
}
@media all and (max-width: 767px) {
  .report li a {
    min-width: auto;
  }
}

.report li a:hover {
  opacity: 0.8;
}

h2 span.tips {
  font-size: 1.125rem;
  padding-right: 20px;
  background: url(../images/input-warn.png) no-repeat right center;
  background-size: 18px auto;
  padding-bottom: 0;
  font-weight: 400;
  margin-left: 15px;
}
@media all and (max-width: 767px) {
  h2 span.tips {
    margin-top: 15px;
    display: inline-block;
    margin-left: 0;
    font-size: 1rem;
  }
}

h2 span.tips::before {
  display: none;
}

.tab-kv {
  margin-bottom: 30px;
}

.buy-card {
  background-color: #fff;
  border-radius: 15px;
  padding: 20px;
}
@media all and (max-width: 767px) {
  .buy-card {
    margin-top: -10px;
  }
}

.buy-card .tit {
  border-bottom: 1px solid #bfbfbf;
  padding-bottom: 18px;
  margin-bottom: 18px;
  position: relative;
}
@media all and (max-width: 767px) {
  .buy-card .tit {
    padding-bottom: 5px;
    margin-bottom: 12px;
  }
}

.buy-card .tit h4 {
  font-size: 1.5rem;
  font-weight: bold;
}
@media all and (max-width: 767px) {
  .buy-card .tit h4 {
    font-size: 1.25rem;
  }
}

.buy-card .tit .price {
  font-size: 1.875rem;
  color: #5887c3;
  font-weight: bold;
  position: absolute;
  right: 0;
  top: -10px;
}
.buy-card .tit .price .or_price {
  font-size: 1rem;
  color: #8c8c8c;
  font-weight: 400;
  text-decoration: line-through;
  padding-left: 10px;
}
@media all and (max-width: 767px) {
  .buy-card .tit .price .or_price {
    padding-left: 0;
  }
}
.buy-card .tit .price .limit {
  border: 1px solid #ff3366;
  color: #ff3366;
  font-size: 1.25rem;
  padding: 2px 20px;
  border-radius: 60px;
  margin-right: 15px;
  position: relative;
  top: -3px;
}
@media all and (max-width: 767px) {
  .buy-card .tit .price .limit {
    font-size: 1rem;
    padding: 0 15px 2px;
    top: -2px;
    margin-right: 10px;
  }
}
@media all and (max-width: 767px) {
  .buy-card .tit .price {
    position: relative;
    right: auto;
    top: auto;
    font-size: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding-top: 10px;
  }
}

.buy-card ul {
  font-size: 1.25rem;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
@media all and (max-width: 767px) {
  .buy-card ul {
    font-size: 1.125rem;
  }
}

.buy-card ul.full li {
  width: 100%;
  margin-right: 0;
  margin-bottom: 8px;
}

.buy-card li {
  padding-left: 25px;
  position: relative;
  width: 48.5%;
  margin-right: 3%;
}
@media all and (max-width: 767px) {
  .buy-card li {
    width: 100%;
    margin-right: 0;
    margin-bottom: 8px;
  }
}

.buy-card li:nth-child(2n) {
  margin-right: 0;
}

.buy-card li::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 12px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}

.buy-card a {
  background-color: #ff3366;
  max-width: 360px;
  width: 100%;
  border-radius: 40px;
  color: #fff;
  font-weight: bold;
  font-size: 1.5rem;
  display: block;
  text-align: center;
  margin: 0 auto;
}
@media all and (max-width: 767px) {
  .buy-card a {
    font-size: 1.25rem;
    padding: 3px;
  }
}

.buy-card a:hover {
  opacity: 0.8;
}

.popupbox .className {
  font-size: 1.5rem;
  color: #ff3366;
  font-weight: bold;
}
@media all and (max-width: 1200px) {
  .popupbox .className {
    font-size: 1.25rem;
  }
}

.pointList {
  font-size: 1.125rem;
  text-align: left;
}

.pointList li {
  padding-left: 30px;
  position: relative;
  font-weight: bold;
  display: flex;
  justify-content: space-between;
}

.popupbox .popup_con .pointList li h4 {
  width: 125px;
  font-size: 1.125rem;
}

.popupbox .popup_con .pointList li p {
  /*position: absolute;
  right: 0;
  top:0;*/
  flex: 1;
  color: #5887c3;
  font-weight: 400;
}

.popupbox .popup_con .pointList.goods li h4 {
  width: 90px;
}

.popupbox .popup_con .pointList.goods li p {
  line-height: 1.5;
  color: #333333;
}

.popupbox .popup_con .color_gray {
  color: #434343;
}

.pointList li::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 12px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}

.decimalList {
  text-align: left;
}

.decimalList li {
  list-style: decimal;
  margin: 0 0 5px 30px;
}

.decimalList.minH {
  min-height: 150px;
}

.cancel.btnBx {
  margin-top: 10px;
  align-items: flex-end;
  z-index: 3;
}
.cancel.btnBx a {
  width: 100%;
  background: #b3b3b3;
}
.cancel.btnBx a.pink {
  background: #ff3366;
}
.cancel.btnBx .total {
  width: 40px;
  flex: 0 0 1;
  margin-left: 10px;
}
.cancel.btnBx .total:hover .tooltip-con {
  opacity: 1;
}

.popupbox .popup_con .d-flex h4 {
  margin-right: 15px;
  margin-bottom: 0;
  white-space: nowrap;
  font-size: 1.125rem;
}
@media all and (max-width: 767px) {
  .popupbox .popup_con .d-flex h4 {
    margin-bottom: 8px;
  }
}

.applyClassBx {
  padding-bottom: 40px;
  margin-bottom: 0px;
  position: relative;
}

.tool-download {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
  background: #fff;
  padding: 20px;
  border-radius: 10px;
}
@media all and (max-width: 1200px) {
  .tool-download {
    flex-direction: column;
  }
}
.tool-download .app-icon {
  font-size: 1.5rem;
  color: #1b1b1b;
  display: flex;
  align-items: center;
  font-weight: bold;
  margin-right: 20px;
}
@media all and (max-width: 1200px) {
  .tool-download .app-icon {
    margin-bottom: 20px;
  }
}
@media all and (max-width: 767px) {
  .tool-download .app-icon {
    font-size: 1.375rem;
  }
}
.tool-download .app-icon .imgbx {
  width: 80px;
  height: 80px;
  display: inline-block;
  margin-right: 10px;
  border-radius: 10px;
  position: relative;
  overflow: hidden;
}
@media all and (max-width: 767px) {
  .tool-download .app-icon .imgbx {
    width: 60px;
    height: 60px;
  }
}
.tool-download .app-icon .imgbx img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.tool-download .download-link {
  display: block;
}
@media all and (max-width: 1200px) {
  .tool-download .download-link {
    display: block;
    width: 100%;
    text-align: center;
    border-top: 1px solid #dfdfdf;
    padding-top: 20px;
  }
}
.tool-download .download-link a {
  background-color: #5887c3;
  color: #fff;
  border-radius: 30px;
  padding: 5px 30px;
  font-size: 1.25rem;
  transition: 0.2s all ease-in-out;
  white-space: nowrap;
}
.tool-download .download-link a.reverse {
  border: 1px solid #5887c3;
  background-color: #fff;
  color: #5887c3;
}
.tool-download .download-link a.reverse span {
  display: inline-block;
  background: url(../images/book.svg) no-repeat center center/contain;
  width: 25px;
  height: 25px;
  position: relative;
  top: 4px;
}
@media all and (max-width: 767px) {
  .tool-download .download-link a.reverse span {
    top: 5px;
  }
}
@media all and (max-width: 767px) {
  .tool-download .download-link a {
    display: block;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 15px;
    font-size: 1.125rem;
  }
}
.tool-download .download-link a + a {
  margin-left: 10px;
}
@media all and (max-width: 767px) {
  .tool-download .download-link a + a {
    margin-left: auto;
  }
}
.tool-download .download-link a:hover {
  opacity: 0.8;
}

.tit-g h2 font {
  font-size: 1.25rem;
  color: #ff3366;
}
@media all and (max-width: 767px) {
  .tit-g h2 font {
    display: block;
    font-size: 1rem;
    padding-top: 20px;
    line-height: 1.4;
  }
}

/*顯碼隱碼控制*/
.passwordbx1,
.passwordbx2 {
  position: relative;
}

.passwordbx1 .show,
.passwordbx2 .show {
  cursor: pointer;
  position: absolute;
  right: 15px;
  top: 8px;
  width: 25px;
}

.passwordbx1 .show .hidden,
.passwordbx2 .show .hidden {
  display: none;
}

.block.first .article {
  padding-bottom: 0;
  margin-top: -20px;
}

.pd-s {
  padding-bottom: 10px;
}

.article {
  margin-top: -30px;
  overflow: hidden;
  padding-bottom: 30px;
}
@media all and (max-width: 767px) {
  .article {
    margin-top: -10px;
  }
}
.article ul {
  display: flex;
  flex-wrap: wrap;
}
.article li {
  width: calc((100% - 30px) / 2);
  margin-right: 30px;
  display: flex;
  align-items: center;
  padding: 30px 0;
  position: relative;
}
.article li.free .imgbx::before {
  content: "免費試閱";
  position: absolute;
  left: 10px;
  top: 10px;
  background-color: #ff3366;
  color: #fff;
  padding: 0 10px;
  border-radius: 30px;
  z-index: 5;
  font-weight: 500;
  z-index: 3;
}
@media all and (max-width: 767px) {
  .article li.free .imgbx::before {
    font-size: 0.875rem;
  }
}
.article li:hover img {
  transform: scale(1.1);
}
.article li::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: calc(100% + 30px);
  background-color: #dadada;
  height: 1px;
}
.article li:nth-child(2n) {
  margin-right: 0;
}
.article li:last-of-type::after {
  content: "";
  width: 1800px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
}
@media all and (max-width: 1200px) {
  .article li {
    width: 100%;
    margin-right: 0;
    padding: 20px 0;
  }
}
.article .txt .tag {
  color: #5887c3;
  font-weight: bold;
  font-size: 1.125rem;
  margin-bottom: 10px;
  position: relative;
  z-index: 6;
}
.article .txt .tag:hover {
  opacity: 0.8;
}
@media all and (max-width: 1200px) {
  .article .txt .tag {
    font-size: 1rem;
  }
}
.article .txt h4 {
  font-size: 1.5rem;
  margin-bottom: 15px;
  color: #000;
  font-weight: bold;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  box-sizing: border-box;
  min-height: 55px;
}
@media all and (max-width: 1200px) {
  .article .txt h4 {
    font-size: 1.125rem;
    min-height: auto;
    margin-bottom: 10px;
  }
}
.article .txt .date {
  color: #96999f;
  padding-left: 25px;
  background: url(../images/sub_date.svg) no-repeat top 3px left;
  background-size: 22px auto;
  font-size: 16px;
  font-weight: 500;
}
.article .imgbx {
  width: 250px;
  border-radius: 8px;
  overflow: hidden;
  margin-right: 20px;
  flex: 0 0 auto;
  position: relative;
  background-color: #000;
}
@media all and (max-width: 1200px) {
  .article .imgbx {
    width: 180px;
    margin-right: 10px;
  }
}
.article .imgbx.video .img::before {
  content: "";
  width: 50px;
  height: 50px;
  background: url(../images/play-index.svg) no-repeat center center/contain;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
}
.article .imgbx.video .img::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, #000 5%, transparent 40%);
  z-index: 2;
  opacity: 0.8;
}
.article .imgbx.video .img img {
  opacity: 0.7;
}
.article .imgbx .time {
  position: absolute;
  left: 12px;
  bottom: 10px;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 500;
  padding-left: 22px;
  background: url(../images/sub_time.svg) no-repeat top 7px left;
  background-size: 18px auto;
  z-index: 3;
}
.article .imgbx .img {
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
}
.article .imgbx .img img {
  position: absolute;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 0.3s all ease-in-out;
}

.lightGray.article {
  margin-top: 0;
}

.lightGray.block + .block {
  margin-top: auto;
}

.lightGray.block .article {
  padding-bottom: 0;
}

.lightGray.article li:last-of-type::after {
  background-color: #eeeeee;
}

.lightGray .article li:last-of-type::after {
  background-color: #f5f5f5;
}

.lightGray .article li.free:last-of-type::after {
  background-color: #eee;
}

.article-inner-tit {
  margin-top: 20px;
  padding-bottom: 10px;
  margin-bottom: 30px;
  border-bottom: 1px solid #dadada;
}
.article-inner-tit h2 {
  font-family: "Noto Serif TC", serif;
  font-weight: 600;
  margin-bottom: 5px;
}
.article-inner-tit .txt {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.article-inner-tit .txt .tag {
  margin-bottom: 0;
}

.tablesy1 table {
  width: 100%;
  text-align: center;
  margin-bottom: 30px;
}
.tablesy1 th {
  background-color: #eee;
  white-space: nowrap;
}
.tablesy1 td,
.tablesy1 th {
  padding: 15px;
  font-size: 1.125rem;
  line-height: 1.5;
}
.tablesy1 td {
  border-bottom: 1px solid #eee;
}
@media all and (max-width: 1200px) {
  .tablesy1 th,
  .tablesy1 td {
    font-size: 1rem;
  }
}
@media all and (max-width: 767px) {
  .tablesy1 table thead {
    border: none;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
  .tablesy1 table tr {
    background: #f5f5f5;
    display: block;
    margin-bottom: 0.625em;
  }
  .tablesy1 table td {
    display: block;
    text-align: right;
    position: relative;
    padding-left: 150px;
    padding: 15px;
  }
  .tablesy1 table td::before {
    content: attr(data-label);
    float: left;
    font-weight: bold;
    text-transform: uppercase;
    position: relative;
    z-index: 2;
    padding-right: 15px;
  }
  .tablesy1 table td:last-child {
    border-bottom: 0;
  }
}

.notify-item {
  position: relative;
  padding: 12px;
  border-bottom: 1px solid #cccccc;
  padding-left: 20px;
  font-size: 1.25rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.notify-item p {
  display: inline-block;
  margin-right: 10px;
}
.notify-item p span.tag {
  background-color: #dc4f6f;
  color: #fff;
  border-radius: 50px;
  font-size: 0.8em;
  padding: 0px 10px;
  display: inline-block;
  margin-left: 5px;
}
.notify-item::after {
  content: "";
  position: absolute;
  left: 0;
  top: 25px;
  width: 8px;
  height: 8px;
  background: #5887c3;
  border-radius: 50%;
}
@media all and (max-width: 767px) {
  .notify-item {
    font-size: 1.125rem;
  }
}

.notify-item:last-of-type {
  border-bottom: none;
}

.notify-item .more {
  flex: 0 0 auto;
  display: flex;
  padding-right: 24px;
  background: url(../images/next.svg) right 6px no-repeat;
  background-size: 20px;
}

.notify-item .more a {
  color: #666;
  font-size: 1rem;
  border-bottom: 1px solid #666;
  display: block;
  white-space: nowrap;
}
.notify-item .more a:hover {
  color: #5887c3;
  border-bottom-color: #5887c3;
}
@media all and (max-width: 767px) {
  .notify-item .more a {
    font-size: 1.125rem;
  }
}

@media screen and (max-width: 500px) {
  .class-tab {
    justify-content: flex-start;
  }
}
@media screen and (max-width: 360px) {
  .class-mainBanner h3 {
    font-size: 1.75rem;
  }
  .class-mainBanner h5,
  .class-mainBanner .time {
    font-size: 1rem;
  }
  .class-mainBanner .btn a {
    font-size: 1.125rem;
  }
}/*# sourceMappingURL=page.css.map */