@charset "UTF-8";
/* CSS Document */
@import url("reset.css");
html {
  font-size: 16px;
}

html * {
  font-size: 1rem;
  font-weight: 400;
}

body,
ul,
li {
  margin: 0px;
  padding: 0px;
  font-family: "Noto Sans TC", "微軟正黑體", "新細明體", "細明體", Arial, "Arial Black";
  font-size: 16px;
  line-height: 25px;
  color: #000;
  letter-spacing: 1px;
  box-sizing: border-box;
}

body {
  position: relative;
}

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

div,
span {
  display: block;
  width: 100%;
}

button {
  display: none;
}

*:focus {
  outline: none;
} /*解決滾動到區塊時出現框線問題*/
h3 {
  font-size: 2vw;
  font-weight: 500;
  line-height: 1.5;
}
@media (max-width: 768px) {
  h3 {
    font-size: 5vw;
    letter-spacing: 0;
  }
}

h4 {
  font-size: 3vw;
}
@media (max-width: 768px) {
  h4 {
    font-size: 6vw;
  }
}

p {
  font-size: 1.15vw;
  font-weight: 300;
  line-height: 1.7;
  color: #000;
  letter-spacing: 2px;
}
@media (max-width: 992px) {
  p {
    font-size: 1.75vw;
    line-height: 1.5;
  }
}
@media (max-width: 768px) {
  p {
    font-size: 3.8vw;
    line-height: 1.5;
  }
}

.pc {
  display: block;
}
@media (max-width: 768px) {
  .pc {
    display: none;
  }
}

.mob {
  display: none;
}
@media (max-width: 768px) {
  .mob {
    display: block;
  }
}

.pad-pc {
  display: block;
}
@media (min-width: 992px) {
  .pad-pc {
    display: none;
  }
}

.pad-h {
  display: none;
}
@media (max-width: 992px) {
  .pad-h {
    display: block;
  }
}

.btn_style {
  transform-origin: center;
  transform: scale(1);
  transition: all 0.15s ease-in-out;
}
.btn_style:hover {
  cursor: pointer;
  transform: scale(0.9);
}

.ajax_loading {
  background: #000 url("../images/loader.gif") center center no-repeat;
}

/*---KV---*/
.kv_w {
  width: 100%;
  position: relative;
}

.kv_box {
  overflow: hidden;
  position: relative;
  z-index: 2;
  margin-top: -1px;
}

.kv_box_m {
  overflow: hidden;
  position: relative;
  z-index: 2;
}

header {
  width: 95%;
  position: absolute;
  left: 2%;
  top: 0.2%;
  z-index: 5;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 1vw 0.5vw;
}
header .logo_box {
  width: 12.3%;
  position: absolute;
  left: 0.5vw;
  top: 10%;
  z-index: 2;
}
@media (max-width: 768px) {
  header .logo_box {
    width: 32.3%;
  }
}
header nav {
  position: relative;
  width: 90%;
  float: right;
}
header nav ul {
  list-style-type: none;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: auto;
}
header nav ul li {
  display: inline-block;
  width: auto;
  padding: 0 1vw;
  border-left: 1px solid #333;
}
header nav ul li a {
  text-decoration: none;
}
header nav ul li a div {
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.5;
  color: #333;
  letter-spacing: 2px;
  transition: all 0.25s ease-in-out;
}
header nav ul li a div:hover {
  transform: scale(1.1);
}

.btn_buy_box {
  display: block;
  width: 7.8%;
  position: fixed;
  right: 1%;
  bottom: 0.5%;
  z-index: 8;
  transform-origin: center;
  animation: buy_ani 1s ease-in-out infinite;
}
@media (max-width: 992px) {
  .btn_buy_box {
    width: 8%;
  }
}
@media (max-width: 768px) {
  .btn_buy_box {
    width: 20%;
    right: 2%;
    bottom: 2%;
  }
}
.btn_buy_box .btn_buy {
  position: relative;
  z-index: 3;
}
.btn_buy_box .btn_buy02 {
  position: relative;
  margin-top: -1.75vw;
  z-index: 2;
}

@keyframes buy_ani {
  0% {
    margin-bottom: 0;
  }
  50% {
    margin-bottom: 1%;
  }
  100% {
    margin-bottom: 0;
  }
}
.swiper-button-prev {
  left: 0px;
}

.swiper-button-next {
  right: 0px;
}

.swiper-button-prev,
.swiper-button-next {
  color: #333;
}

.swiper-pagination-bullet {
  width: 0.75vw;
  height: 0.75vw;
  margin: 5px;
  background: none;
  border: 1px solid #23569d;
  opacity: 1;
  margin-top: 2%;
}
@media (max-width: 768px) {
  .swiper-pagination-bullet {
    width: 3vw;
    height: 3vw;
    margin: 3px;
  }
}

.swiper-pagination-bullet-active {
  background: #23569d;
}

.swiper-pagination {
  position: relative;
  text-align: center;
}

main,
section {
  display: block;
  width: 100%;
  position: relative;
}

main {
  overflow: hidden;
}

.yt_box {
  width: 100%;
  margin: 0px auto 0;
  position: relative;
}

.vidbacking {
  display: block;
}

.video-back {
  display: block; /*padding:200px 0px;*/
  text-align: center;
}

.video-back img {
  /*width:150px;*/
  width: 100%;
  height: auto;
}

img.vediobg_img {
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  top: 0;
  z-index: -101;
}

.video-container {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}

.video-container iframe,
.video-container object,
.video-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#background-video > .ytplayer-container > iframe {
  top: 0 !important;
  z-index: -1;
}

.placeholder-image {
  z-index: 100;
  top: 0;
}

@media (max-width: 767px) {
  .ytplayer-player {
    top: 0 !important;
  }
}

.yt_box {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.yt_box img {
  position: relative;
  z-index: 2;
}

/* png 當作比例容器 */
.placeholder-image {
  width: 100%;
  height: auto; /* 讓 png 自己決定高度 */
  display: block;
}

/* YouTube API 會塞的 iframe，讓它鋪滿當背景 */
.yt_box iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover; /* 用 CSS 撐滿比例容器 */
  z-index: -1;
}

/*---s01---*/
#s01 {
  position: relative;
  z-index: 2;
  background: url(../images/s01/s01_bg.png) no-repeat top center;
  background-size: cover;
  overflow: hidden;
  padding: 10% 0 5%;
}
@media (max-width: 768px) {
  #s01 {
    padding: 25% 0 5%;
  }
}

.box_w {
  display: block;
  width: 100%;
  position: relative;
  text-align: center;
  margin: 0 auto;
}

.prd_w {
  position: relative;
}
.prd_w h2 {
  width: 61.4%;
  margin: 2% auto;
}
@media (max-width: 768px) {
  .prd_w h2 {
    width: 91.4%;
  }
}
.prd_w .prd_all {
  width: 82.4%;
  position: relative;
  margin: 0 auto 2%;
  z-index: 2;
}
.prd_w .prd_all .prd_list {
  width: 85%;
  position: relative;
  margin: 0 auto 5%;
  overflow: hidden;
}

.prd_box {
  position: relative;
}
.prd_box .prd_title {
  position: relative;
}
.prd_box .prd_title h3 {
  font-size: 1.6vw;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 992px) {
  .prd_box .prd_title h3 {
    font-size: 3.6vw;
  }
}
@media (max-width: 768px) {
  .prd_box .prd_title h3 {
    font-size: 6vw;
  }
}
.prd_box .prd_title .prd_twd {
  font-size: 1.05vw;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 992px) {
  .prd_box .prd_title .prd_twd {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .prd_box .prd_title .prd_twd {
    font-size: 3.5vw;
  }
}
.prd_box .prd_title .prd_twd span {
  display: inline;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  font-size: 2.6vw;
  line-height: 1.5;
  color: #e84e6d;
}
@media (max-width: 992px) {
  .prd_box .prd_title .prd_twd span {
    font-size: 4.6vw;
  }
}
@media (max-width: 768px) {
  .prd_box .prd_title .prd_twd span {
    font-size: 8vw;
  }
}
.prd_box .prd_photo {
  position: relative;
  margin: 5% auto;
}

.btn_prd {
  display: inline-block;
  width: auto;
  margin: 0 auto;
  position: relative;
}
.btn_prd a {
  text-decoration: none;
}
.btn_prd a div {
  display: inline-block;
  width: auto;
  font-size: 1.2vw;
  line-height: 1.25;
  color: #fff;
  position: relative;
  background: #4273cc;
  border: 1px solid white;
  border-radius: 50vw;
  padding: 0.25vw 2vw 0.25vw 1.15vw;
  box-sizing: border-box;
  transition: all 0.25s ease-in-out;
}
@media (max-width: 992px) {
  .btn_prd a div {
    font-size: 2vw;
    padding: 0.5vw 4vw 0.5vw 2vw;
  }
}
@media (max-width: 768px) {
  .btn_prd a div {
    font-size: 4vw;
    padding: 1.5vw 8vw 1.5vw 5.15vw;
  }
}
.btn_prd a div::after {
  display: inline-block;
  content: "》";
  width: 1vw;
  height: 1.5vw;
  font-size: 1vw;
  color: #fff;
  opacity: 0.5;
  position: absolute;
  right: 0.55vw;
  top: 0.35vw;
  z-index: 2;
}
@media (max-width: 992px) {
  .btn_prd a div::after {
    width: 2vw;
    height: 3.5vw;
    font-size: 2vw;
    right: 1.5vw;
    top: 0.5vw;
  }
}
@media (max-width: 768px) {
  .btn_prd a div::after {
    width: 3.8vw;
    height: 4.5vw;
    font-size: 3.8vw;
    right: 2.5vw;
    top: 1.5vw;
  }
}
.btn_prd a:hover div {
  background: #e84e6d;
}
.btn_prd a:hover div::after {
  animation: btn_arrow 0.5s infinite;
}

@keyframes btn_arrow {
  0% {
    right: 0.55vw;
  }
  50% {
    right: 0.25vw;
  }
  100% {
    right: 0.55vw;
  }
}
@media (max-width: 992px) {
  @keyframes btn_arrow {
    0% {
      right: 1.5vw;
    }
    50% {
      right: 1vw;
    }
    100% {
      right: 1.5vw;
    }
  }
}
@media (max-width: 768px) {
  @keyframes btn_arrow {
    0% {
      right: 2.5vw;
    }
    50% {
      right: 1vw;
    }
    100% {
      right: 2.5vw;
    }
  }
}
.ticket01 {
  width: 12.8%;
  position: absolute;
  left: -5.8%;
  bottom: 2%;
  z-index: 2;
}
@media (max-width: 768px) {
  .ticket01 {
    width: 25%;
  }
}

.ticket02 {
  width: 9.5%;
  position: absolute;
  right: -2.5%;
  top: -2%;
  z-index: 2;
}
@media (max-width: 768px) {
  .ticket02 {
    width: 22%;
  }
}

/*---s02---*/
#s02 {
  position: relative;
  background: url(../images/s02/s02_bg.png) no-repeat center;
  background-size: cover;
}

.blue_bg {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  background: rgba(0, 18, 93, 0.7);
}

.time_w {
  width: 82.4%;
  position: relative;
  margin: 0% auto;
  padding: 6% 0;
  z-index: 3;
}
@media (max-width: 768px) {
  .time_w {
    width: 90%;
  }
}
.time_w .title_box {
  width: 42.9%;
  position: relative;
  margin: 0% auto;
  color: #fff;
}
@media (max-width: 992px) {
  .time_w .title_box {
    width: 52.9%;
  }
}
@media (max-width: 768px) {
  .time_w .title_box {
    width: 72.9%;
  }
}
.time_w .title_box .en {
  font-size: 0.89vw;
  letter-spacing: 1vw;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .time_w .title_box .en {
    font-size: 1.25vw;
  }
}
@media (max-width: 768px) {
  .time_w .title_box .en {
    font-size: 2vw;
  }
}
.time_w .title_box h2 {
  display: inline-block;
  width: 100%;
  font-size: 2vw;
  line-height: 1.5;
  text-align: center;
  border-bottom: 1px solid #fff;
  padding-bottom: 1vw;
}
@media (max-width: 992px) {
  .time_w .title_box h2 {
    font-size: 3vw;
  }
}
@media (max-width: 768px) {
  .time_w .title_box h2 {
    font-size: 4vw;
  }
}
.time_w .title_box h2 span {
  display: inline;
  font-size: 1.5vw;
}
@media (max-width: 768px) {
  .time_w .title_box h2 span {
    font-size: 2.5vw;
  }
}
.time_w .title_box h3 {
  font-size: 3.6vw;
  font-weight: 600;
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .time_w .title_box h3 {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .time_w .title_box h3 {
    font-size: 6vw;
  }
}
.time_w .title_box h3 span {
  display: inline;
  font-size: 3.6vw;
  font-weight: 600;
  color: #faee00;
}
@media (max-width: 992px) {
  .time_w .title_box h3 span {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .time_w .title_box h3 span {
    font-size: 6vw;
  }
}
.time_w .time_prd {
  font-size: 0.89vw;
  color: #fff;
  margin: 2% 0;
}
@media (max-width: 992px) {
  .time_w .time_prd {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .time_w .time_prd {
    font-size: 3vw;
  }
}
.time_w .time_prd span {
  display: inline;
  font-size: 1.8vw;
  color: #faee00;
}
.time_w .time_prd .prd_twd {
  display: inline;
  font-family: Verdana, Geneva, Tahoma, sans-serif;
  font-size: 3vw;
  color: #faee00;
}
@media (max-width: 992px) {
  .time_w .time_prd .prd_twd {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .time_w .time_prd .prd_twd {
    font-size: 7vw;
  }
}

.btn_more {
  display: inline-block;
  width: auto;
  margin: 0 auto;
  position: relative;
}
@media (max-width: 768px) {
  .btn_more {
    margin: 2% auto;
  }
}
.btn_more a {
  text-decoration: none;
}
.btn_more a div {
  display: inline-block;
  width: auto;
  font-size: 1.2vw;
  line-height: 1.25;
  color: #fff;
  position: relative;
  border: 1px solid white;
  border-radius: 50vw;
  padding: 0.25vw 2vw 0.25vw 1.15vw;
  box-sizing: border-box;
  transition: all 0.25s ease-in-out;
}
@media (max-width: 992px) {
  .btn_more a div {
    font-size: 2vw;
    padding: 0.5vw 4vw 0.5vw 2vw;
  }
}
@media (max-width: 768px) {
  .btn_more a div {
    font-size: 4vw;
    padding: 1.5vw 8vw 1.5vw 5.15vw;
  }
}
.btn_more a div::after {
  display: inline-block;
  content: "》";
  width: 1vw;
  height: 1vw;
  font-size: 1vw;
  color: #fff;
  opacity: 0.5;
  position: absolute;
  right: 8%;
  top: 0.35vw;
  z-index: 2;
}
@media (max-width: 992px) {
  .btn_more a div::after {
    width: 2vw;
    height: 3.5vw;
    font-size: 2vw;
    right: 1.5vw;
    top: 0.5vw;
  }
}
@media (max-width: 768px) {
  .btn_more a div::after {
    width: 3.8vw;
    height: 4.5vw;
    font-size: 3.8vw;
    right: 2.5vw;
    top: 1.5vw;
  }
}
.btn_more a:hover div {
  background: #e84e6d;
}
.btn_more a:hover div::after {
  animation: btn_arrow 0.5s infinite;
}

.timetable_box {
  width: 49.1%;
  position: relative;
  margin: -6vw auto 0;
  z-index: -1;
}
@media (max-width: 992px) {
  .timetable_box {
    width: 59.1%;
    margin: -5vw auto 0;
  }
}
@media (max-width: 768px) {
  .timetable_box {
    width: 90%;
    margin: -10vw auto 0;
  }
}
.timetable_box .flower {
  width: 18.7%;
}

/*---line---*/
.line_bar {
  position: relative;
  background: #02c100;
}
.line_bar .line {
  width: 34.2%;
  margin: 0 auto;
}
@media (max-width: 992px) {
  .line_bar .line {
    width: 38%;
  }
}
@media (max-width: 768px) {
  .line_bar .line {
    width: 70%;
  }
}

/*---s03---*/
#s03 {
  position: relative;
  background: url(../images/s03/s03_bg.png) no-repeat center;
  background-size: cover;
  padding: 5% 0;
}

.event01_w {
  position: relative;
  width: 100%;
}
.event01_w h2 {
  width: 50%;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .event01_w h2 {
    width: 80%;
  }
}
.event01_w .event01_info {
  width: 82.4%;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .event01_w .event01_info {
    width: 90%;
  }
}
.event01_w .event01_info p {
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
}
.event01_w .event01_info p span {
  font-size: 2vw;
  font-weight: bold;
  color: #e84e6d;
  text-align: center;
}
@media (max-width: 768px) {
  .event01_w .event01_info p span {
    font-size: 5vw;
  }
}
.event01_w .event01_info ul.event01_rules_list {
  width: 53.2%;
  position: relative;
  list-style-type: none;
  margin: 2% auto;
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list {
    width: 95%;
    margin: 5% auto;
  }
}
.event01_w .event01_info ul.event01_rules_list li {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: flex-start;
  margin: 1vw 0;
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list li {
    margin: 2vw 0;
  }
}
.event01_w .event01_info ul.event01_rules_list li .item {
  display: inline-block;
  width: 8vw;
  font-size: 1.3vw;
  font-weight: bold;
  color: #e84e6d;
  text-align: center;
  border: 1px solid #e84e6d;
  border-radius: 50vw;
  padding: 0.25vw 0vw;
}
@media (max-width: 992px) {
  .event01_w .event01_info ul.event01_rules_list li .item {
    width: 10vw;
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list li .item {
    width: 22vw;
    font-size: 3.8vw;
    padding: 0.5vw 0vw;
  }
}
.event01_w .event01_info ul.event01_rules_list li .item_text {
  display: inline-block;
  width: calc(100% - 8vw - 1vw);
  font-size: 1.3vw;
  line-height: 1.5;
  color: #000;
  text-align: justify;
}
@media (max-width: 992px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text {
    width: calc(100% - 10vw - 1vw);
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text {
    width: calc(100% - 0vw - 1vw);
    font-size: 3.8vw;
    padding-left: 3vw;
  }
}
.event01_w .event01_info ul.event01_rules_list li .item_text ol {
  list-style-type: decimal;
  padding-left: 1.5vw;
  box-sizing: border-box;
}
@media (max-width: 992px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text ol {
    padding-left: 0.5vw;
  }
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text ol {
    padding-left: 1.5vw;
  }
}
.event01_w .event01_info ul.event01_rules_list li .item_text ol li {
  display: list-item;
  list-style-type: decimal;
  font-size: 1.3vw;
  font-weight: 400;
  color: #000;
  line-height: 1.7;
  text-align: justify;
  margin: 0;
}
@media (max-width: 992px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text ol li {
    font-size: 1.75vw;
    margin-left: 1.75vw;
  }
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list li .item_text ol li {
    font-size: 3.8vw;
    margin-left: 4vw;
  }
}
.event01_w .event01_info ul.event01_rules_list .mail {
  width: 13%;
  position: absolute;
  left: -15%;
  top: -10%;
  z-index: 2;
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list .mail {
    width: 23%;
    left: -10%;
    top: -27%;
  }
}
.event01_w .event01_info ul.event01_rules_list .heart {
  width: 14.2%;
  position: absolute;
  right: -14.2%;
  bottom: 2.5%;
  z-index: 2;
}
@media (max-width: 768px) {
  .event01_w .event01_info ul.event01_rules_list .heart {
    width: 24.2%;
    right: -10.2%;
  }
}
.event01_w .event01_info .award_list {
  position: relative;
  margin: 0 auto;
}

.award_box {
  position: relative;
}
.award_box .award_info {
  font-size: 1.2vw;
  line-height: 1.7;
  text-align: center;
  letter-spacing: 0;
}
@media (max-width: 992px) {
  .award_box .award_info {
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .award_box .award_info {
    font-size: 3.5vw;
    letter-spacing: -0.1vw;
  }
}

#swiper-container02 {
  overflow: hidden;
}
@media (max-width: 991px) {
  #swiper-container02 {
    display: none;
  }
}
@media (min-width: 992px) {
  #swiper-container02 {
    display: block;
  }
}

#swiper-container02 > .swiper-wrapper {
  flex-direction: row;
}

#swiper-container02m {
  overflow: hidden;
}
@media (max-width: 991px) {
  #swiper-container02m {
    display: block;
  }
}
@media (min-width: 992px) {
  #swiper-container02m {
    display: none;
  }
}

#swiper-container02m > .swiper-wrapper {
  flex-direction: row;
}

.btn_box {
  position: relative;
  margin: 2% auto 5%;
}
.btn_box .btn_rules_text {
  position: relative;
}
.btn_box .btn_rules_text a {
  color: #000;
  text-decoration: underline;
}
.btn_box .btn_rules_text a span {
  font-size: 1vw;
  font-weight: 400;
  color: #000;
  margin: 1vw auto;
}
@media (max-width: 992px) {
  .btn_box .btn_rules_text a span {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .btn_box .btn_rules_text a span {
    font-size: 3.5vw;
  }
}

/*---s04---*/
#s04 {
  position: relative;
  background: url(../images/s04/s04_bg.png) no-repeat center;
  background-size: cover;
}

.kstf_w {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.kstf_w .kstf_all {
  width: 82.5%;
  position: relative;
  margin: 0 auto;
  padding: 10% 0;
  z-index: 3;
}
.kstf_w .kstf_all .en {
  font-size: 0.89vw;
  color: #fff;
  letter-spacing: 1vw;
}
@media (max-width: 992px) {
  .kstf_w .kstf_all .en {
    font-size: 1.25vw;
  }
}
@media (max-width: 768px) {
  .kstf_w .kstf_all .en {
    font-size: 2vw;
  }
}
.kstf_w .kstf_all .kstf_info {
  font-size: 3.6vw;
  font-weight: bold;
  line-height: 1.25;
  color: #fff;
}
@media (max-width: 992px) {
  .kstf_w .kstf_all .kstf_info {
    font-size: 4vw;
  }
}
@media (max-width: 768px) {
  .kstf_w .kstf_all .kstf_info {
    font-size: 5vw;
    line-height: 1.5;
  }
}
.kstf_w .kstf_all .kstf_sale {
  font-size: 3.6vw;
  font-weight: bold;
  line-height: 1.25;
  color: #faee00;
  margin: 1.5% 0;
}
@media (max-width: 992px) {
  .kstf_w .kstf_all .kstf_sale {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .kstf_w .kstf_all .kstf_sale {
    font-size: 6vw;
  }
}
.kstf_w .kstf_all .kstf_sale span {
  display: inline;
  font-size: 1vw;
  color: #faee00;
}
@media (max-width: 992px) {
  .kstf_w .kstf_all .kstf_sale span {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .kstf_w .kstf_all .kstf_sale span {
    font-size: 3vw;
  }
}

/*---s05--*/
#s05 {
  position: relative;
  background: url(../images/s05/s05_bg.png) no-repeat top center;
  background-size: cover;
  padding: 5% 0;
}

.event02_w {
  position: relative;
  margin: 0 auto;
}
.event02_w .event02_all {
  position: relative;
}
.event02_w .event02_all h2 {
  width: 61.4%;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .event02_w .event02_all h2 {
    width: 91.4%;
  }
}
.event02_w .event02_all p {
  font-weight: 400;
  text-align: center;
}
.event02_w .event02_all .event02_1 {
  width: 87.1%;
  position: relative;
  margin: 1% auto 5%;
}

#swiper-container03 {
  overflow: hidden;
}

.swiper-button-prev.swp03 {
  left: -2.5vw;
}

.swiper-button-next.swp03 {
  right: -2.5vw;
}

#swiper-container03_2 {
  overflow: hidden;
}

.swiper-button-prev.swp03_2 {
  left: -2.5vw;
}

.swiper-button-next.swp03_2 {
  right: -2.5vw;
}

.event02_3 {
  width: 46.3%;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: stretch;
  margin: 1% auto 10%;
}
@media (max-width: 992px) {
  .event02_3 {
    width: 66.3%;
  }
}
@media (max-width: 768px) {
  .event02_3 {
    width: 86.3%;
    margin: 5% auto 20%;
  }
}
.event02_3 .yt_g {
  width: 45.3%;
  position: relative;
}
.event02_3 .yt_info {
  width: 48.6%;
}

/* shorts 容器：隨 .yt_g 改變寬度並固定 9:16 */
.video-container-shorts {
  width: 100%; /* ★ 吃滿 .yt_g → 跟著等比例變化主因 */
  aspect-ratio: 9/16;
  position: relative;
  overflow: hidden;
}

/* 填滿固定比例區域 */
.video-container-shorts iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.mail02 {
  width: 13.4%;
  position: absolute;
  left: -25%;
  bottom: 10%;
  z-index: 2;
}
@media (max-width: 768px) {
  .mail02 {
    width: 23.4%;
    left: -10%;
    bottom: -15%;
  }
}

.heart02 {
  width: 13.4%;
  position: absolute;
  right: -25%;
  top: 10%;
  z-index: 2;
}
@media (max-width: 768px) {
  .heart02 {
    width: 23.4%;
    right: -10%;
    top: -22%;
  }
}

#swiper-container03_4 {
  overflow: hidden;
}

.swiper-button-prev.swp03_4 {
  left: -2.5vw;
}

.swiper-button-next.swp03_4 {
  right: -2.5vw;
}

/*---s06--*/
#s06 {
  position: relative;
  background: url(../images/s06/s06_bg.png) no-repeat top center;
  background-size: cover;
}

.a321neo_w {
  position: relative;
  padding: 5% 0;
}
.a321neo_w .a321neo_all {
  width: 82.5%;
  position: relative;
  margin: 0 auto;
  z-index: 3;
}
.a321neo_w .a321neo_all .title_box {
  width: 42.9%;
  position: relative;
  margin: 0% auto;
  color: #fff;
}
@media (max-width: 992px) {
  .a321neo_w .a321neo_all .title_box {
    width: 52.9%;
  }
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all .title_box {
    width: 100%;
  }
}
.a321neo_w .a321neo_all .title_box .en {
  font-size: 0.89vw;
  letter-spacing: 1vw;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .a321neo_w .a321neo_all .title_box .en {
    font-size: 1.25vw;
  }
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all .title_box .en {
    font-size: 2vw;
  }
}
.a321neo_w .a321neo_all .title_box h2 {
  display: inline-block;
  width: 100%;
  font-size: 3.6vw;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  border-bottom: 1px solid #fff;
}
@media (max-width: 992px) {
  .a321neo_w .a321neo_all .title_box h2 {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all .title_box h2 {
    font-size: 6vw;
  }
}
.a321neo_w .a321neo_all .title_box h2 span {
  display: inline;
  font-size: 3.6vw;
  font-weight: 600;
  color: #faee00;
}
@media (max-width: 992px) {
  .a321neo_w .a321neo_all .title_box h2 span {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all .title_box h2 span {
    font-size: 6vw;
  }
}
.a321neo_w .a321neo_all .title_box h3 {
  font-size: 2.3vw;
  font-weight: 400;
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .a321neo_w .a321neo_all .title_box h3 {
    font-size: 3vw;
  }
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all .title_box h3 {
    font-size: 4vw;
  }
}
.a321neo_w .a321neo_all p {
  line-height: 1.7;
  color: #fff;
  text-align: center;
  margin: 2% auto;
}
@media (max-width: 768px) {
  .a321neo_w .a321neo_all p {
    text-align: justify;
  }
}

/*---s07--*/
#s07 {
  position: relative;
  background: url(../images/s07/s07_bg.png) no-repeat top center;
  background-size: cover;
}

.pikachu_w {
  position: relative;
}
.pikachu_w .pikachu_all {
  width: 82.5%;
  position: relative;
  margin: 0 auto;
  padding: 5% 0;
}
.pikachu_w .pikachu_all h2 {
  width: 59.9%;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .pikachu_w .pikachu_all h2 {
    width: 90%;
    margin: 5% auto;
  }
}
.pikachu_w .pikachu_all .airplane {
  width: 75.7%;
  margin: 2.5% auto;
}
@media (max-width: 768px) {
  .pikachu_w .pikachu_all .airplane {
    width: 100%;
    margin: 5% auto 10%;
  }
}
.pikachu_w .pikachu_all .pikachu_info {
  position: relative;
}
.pikachu_w .pikachu_all .pikachu_info h3 {
  font-size: 2.3vw;
  font-weight: 600;
  line-height: 1.7;
  letter-spacing: 1vw;
  color: #4273cc;
  text-align: center;
}
@media (max-width: 768px) {
  .pikachu_w .pikachu_all .pikachu_info h3 {
    font-size: 5vw;
  }
}
.pikachu_w .pikachu_all .pikachu_info p {
  font-weight: 400;
  line-height: 1.7;
  text-align: center;
}

.copy_text {
  position: relative;
  font-size: 0.75vw;
  text-align: center;
  margin: 2.5% auto 0;
}
@media (max-width: 992px) {
  .copy_text {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .copy_text {
    font-size: 2vw;
    line-height: 1.5;
    letter-spacing: 0;
  }
}

.pikachu01 {
  width: 17.6%;
  position: absolute;
  left: 0%;
  top: -25%;
  z-index: 2;
}
@media (max-width: 992px) {
  .pikachu01 {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .pikachu01 {
    left: -5%;
  }
}
.pikachu01 img {
  animation: pikachu01 1s ease-in-out infinite;
}

@keyframes pikachu01 {
  0% {
    margin-top: 0;
  }
  50% {
    margin-top: 5%;
  }
  100% {
    margin-top: 0;
  }
}
.pikachu02 {
  width: 17.6%;
  position: absolute;
  right: 0%;
  top: -10%;
  z-index: 2;
}
@media (max-width: 992px) {
  .pikachu02 {
    right: -5vw;
  }
}
@media (max-width: 768px) {
  .pikachu02 {
    width: 27.6%;
    right: -5%;
    top: -15%;
  }
}
.pikachu02 img {
  animation: pikachu02 1s ease-in-out infinite;
}

@keyframes pikachu02 {
  0% {
    margin-top: 5%;
  }
  50% {
    margin-top: 0%;
  }
  100% {
    margin-top: 5%;
  }
}
/*---s08--*/
#s08 {
  position: relative;
  background: url(../images/s08/s08_bg.png) no-repeat top center;
  background-size: cover;
}

.esg_w {
  position: relative;
}
.esg_w .esg_all {
  width: 82.5%;
  position: relative;
  margin: 0 auto;
  padding: 5% 0;
  z-index: 3;
}
@media (max-width: 992px) {
  .esg_w .esg_all {
    width: 90%;
    padding: 5% 0 45%;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all {
    width: 90%;
    padding: 5% 0 45%;
  }
}
.esg_w .esg_all .title_box {
  width: 42.9%;
  position: relative;
  margin: 0% auto;
  color: #fff;
}
@media (max-width: 992px) {
  .esg_w .esg_all .title_box {
    width: 52.9%;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all .title_box {
    width: 82.9%;
  }
}
.esg_w .esg_all .title_box .en {
  font-size: 0.89vw;
  letter-spacing: 1vw;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .esg_w .esg_all .title_box .en {
    font-size: 1.25vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all .title_box .en {
    font-size: 2vw;
  }
}
.esg_w .esg_all .title_box h2 {
  display: inline-block;
  width: 100%;
  font-size: 3.6vw;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  border-bottom: 1px solid #fff;
}
@media (max-width: 992px) {
  .esg_w .esg_all .title_box h2 {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all .title_box h2 {
    font-size: 6vw;
  }
}
.esg_w .esg_all .title_box h2 span {
  display: inline;
  font-size: 3.6vw;
  font-weight: 600;
  color: #faee00;
}
@media (max-width: 992px) {
  .esg_w .esg_all .title_box h2 span {
    font-size: 5vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all .title_box h2 span {
    font-size: 6vw;
  }
}
.esg_w .esg_all .title_box h3 {
  font-size: 2.3vw;
  font-weight: 400;
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .esg_w .esg_all .title_box h3 {
    font-size: 4vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all .title_box h3 {
    font-size: 4vw;
  }
}
.esg_w .esg_all p {
  width: 68%;
  line-height: 1.7;
  color: #fff;
  text-align: center;
  margin: 2% auto;
}
@media (max-width: 768px) {
  .esg_w .esg_all p {
    width: 95%;
    text-align: justify;
    letter-spacing: 0;
  }
}
.esg_w .esg_all p.more_box {
  font-size: 1.35vw;
  font-weight: 400;
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media (max-width: 992px) {
  .esg_w .esg_all p.more_box {
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all p.more_box {
    font-size: 3.5vw;
  }
}
.esg_w .esg_all p.more_box a {
  display: inline;
  font-size: 1.35vw;
  color: #faee00;
  text-decoration: underline;
}
@media (max-width: 992px) {
  .esg_w .esg_all p.more_box a {
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .esg_w .esg_all p.more_box a {
    font-size: 3.5vw;
    letter-spacing: 0;
  }
}

.esg_info_g {
  width: 79.5%;
  position: relative;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
}
@media (max-width: 992px) {
  .esg_info_g {
    width: 90%;
  }
}
@media (max-width: 768px) {
  .esg_info_g {
    width: 95%;
    justify-content: space-between;
  }
}
.esg_info_g .pic_esg {
  width: 23.8%;
  order: 2;
}
@media (max-width: 768px) {
  .esg_info_g .pic_esg {
    width: 70%;
    margin: 0 auto 5%;
    order: 1;
  }
}
.esg_info_g .esg_info {
  width: 37.1%;
  position: relative;
}
@media (max-width: 768px) {
  .esg_info_g .esg_info {
    width: 100%;
  }
}
.esg_info_g .esg_info h3 {
  font-size: 1.8vw;
  font-weight: 600;
  line-height: 1.5;
  color: #faee00;
  text-align: justify;
}
@media (max-width: 768px) {
  .esg_info_g .esg_info h3 {
    font-size: 5vw;
  }
}
.esg_info_g .esg_info p {
  width: 100%;
  font-size: 1.1vw;
  font-weight: 400;
  line-height: 1.5;
  color: #fff;
  text-align: justify;
}
@media (max-width: 992px) {
  .esg_info_g .esg_info p {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .esg_info_g .esg_info p {
    font-size: 3.5vw;
  }
}

.esg01 {
  order: 1;
}
@media (max-width: 768px) {
  .esg01 {
    order: 2;
  }
}

.esg02 {
  order: 3;
}
@media (max-width: 768px) {
  .esg02 {
    order: 3;
  }
}

/*---popup / 注意事項---*/
/*---popup---*/
.modally {
  width: 70.3%;
  background: none;
  box-shadow: none;
  padding: 4px;
}
@media (max-width: 991px) {
  .modally {
    width: 90%;
  }
}

.modally .modally-close-button {
  display: block;
  font-size: 50px;
  color: #fff;
}

.modally-wrap .modally-underlay {
  background: rgba(0, 18, 93, 0.9);
  background-size: 100%;
}

/*popup / 分享圖*/
.event-w {
  width: 60.2%;
  margin: 0% auto;
  padding: 5% 0;
  position: relative;
}

/*popup / 活動辦法*/
.rules-w {
  width: 90%;
  margin: 0% auto;
  padding: 5% 0;
  position: relative;
}
.rules-w h2 {
  display: block;
  width: 100%;
  font-size: 2vw;
  font-weight: bold;
  line-height: 1.5;
  color: #faee00;
  text-align: center;
  margin: 0 auto 2%;
}
@media (max-width: 992px) {
  .rules-w h2 {
    font-size: 4vw;
  }
}
@media (max-width: 768px) {
  .rules-w h2 {
    font-size: 5vw;
  }
}

ul.ps_text {
  list-style-type: none;
  display: flex;
  flex-flow: column wrap;
  font-size: 1vw;
  line-height: 1.5;
  margin: 0 auto 0%;
  padding-left: 2.5%;
}
ul.ps_text li {
  width: 100%;
  list-style-type: disc;
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  color: #fff;
  margin: 1% 0 1% 0%;
}
@media (max-width: 992px) {
  ul.ps_text li {
    width: 100%;
    margin: 1% 0 1% 0%;
    font-size: 3vw;
  }
}
ul.ps_text li a {
  font-size: 1vw;
  color: #faee00;
  text-decoration: underline;
}
@media (max-width: 992px) {
  ul.ps_text li a {
    font-size: 3vw;
  }
}
ul.ps_text li ol {
  list-style-type: decimal-leading-zero;
  padding-left: 5%;
}
ul.ps_text li ol li {
  width: 100%;
  list-style-type: decimal-leading-zero;
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  color: #fff;
  margin: 1% 0 1% 0%;
}
@media (max-width: 992px) {
  ul.ps_text li ol li {
    width: 100%;
    font-size: 3vw;
    margin: 2% 0;
  }
}

/*-------------------------------------------------------------*/
.overlay {
  width: 100%;
  background: rgba(35, 86, 157, 0.9);
}

.overlay nav {
  top: 0vh;
  height: 95vh;
}
.overlay nav ul {
  display: block;
  width: 100%;
  height: 100%;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  padding: 10%;
}
.overlay nav ul a {
  text-decoration: none;
}
.overlay nav ul a li {
  width: 100%;
  display: flex;
  border-bottom: 1px solid #fff;
}
.overlay nav ul a li div {
  display: inline;
  width: 100%;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 2;
  color: #fff;
  justify-content: flex-start;
  align-items: center;
  padding: 10px;
  letter-spacing: 5px;
}
.overlay nav ul a li div span {
  display: inline;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 2;
  color: #ed425a;
  letter-spacing: 5px;
}
.overlay nav ul a li div p {
  font-size: 5vw;
  font-weight: 600;
}

.overlay .overlay-close {
  top: 0;
}

.overlay .overlay-close {
  max-width: 58px;
  max-height: 58px;
}

button.menu_m {
  display: block;
  width: 3.2%;
  position: relative;
  border: none;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top center;
  padding: 0;
  background-color: transparent;
  text-indent: -9999px;
  cursor: pointer;
  z-index: 990;
  outline: 0;
  order: 3;
}
@media (max-width: 992px) {
  button.menu_m {
    width: 6.2%;
  }
}
@media (max-width: 768px) {
  button.menu_m {
    width: 13.2%;
  }
}/*# sourceMappingURL=style.css.map */