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

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

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

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

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

button {
  display: none;
}

*:focus {
  outline: none;
} /*解決滾動到區塊時出現框線問題*/
p {
  font-size: 1.15vw;
  line-height: 1.8;
  color: #5c5b53;
  font-weight: 400;
}
@media (max-width: 768px) {
  p {
    font-size: 3.5vw;
  }
}

.ls-5 {
  letter-spacing: 2px;
}

.ml-7 {
  margin-left: 7%;
}

.mtb-2 {
  margin-top: 2%;
  margin-bottom: 2%;
}

.mtb-5 {
  margin-top: 5%;
  margin-bottom: 5%;
}

.ptb-1 {
  padding-top: 1%;
  padding-bottom: 1%;
}

.plr-2 {
  padding-left: 2%;
  padding-right: 2%;
}

.bt-1 {
  border-bottom: 1px solid #fff;
}

.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);
}

/*---kv---*/
header {
  width: 96%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  left: 2%;
  top: 2%;
  margin: 0 auto;
  padding: 0.5% 1% 2%;
  z-index: 7;
}
@media (max-width: 768px) {
  header {
    top: 1%;
  }
}
header .logo_box {
  width: 8.1%;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 2;
}
@media (max-width: 992px) {
  header .logo_box {
    width: 19.2%;
  }
}
@media (max-width: 768px) {
  header .logo_box {
    width: 27%;
  }
}
header .logo_box .logo01 {
  width: 100%;
}
header nav {
  width: 80%;
  position: relative;
  display: inline-block;
  text-align: right;
}
@media (max-width: 768px) {
  header nav {
    display: none;
  }
}
header nav ul {
  position: relative;
}
header nav ul li {
  display: inline;
  width: auto;
  padding: 0 1%;
  border-left: 1px solid #3e3a39;
}
header nav ul li:last-child {
  border-right: 1px solid #3e3a39;
}
header nav ul li a {
  text-decoration: none;
  font-size: 0;
}
header nav ul li a span {
  display: inline;
  font-size: 0.85vw;
  font-weight: 500;
  line-height: 1.2;
  color: #8a9596;
  letter-spacing: 0.15vw;
  text-indent: 0.15vw;
  text-align: center;
  transition: all 0.5s ease-in-out;
}
@media (max-width: 992px) {
  header nav ul li a span {
    font-size: 1.5vw;
  }
}
header nav ul li a:hover span {
  color: #ef845c;
}

.kv_w {
  position: relative;
  overflow: hidden;
  overflow: hidden;
}
.kv_w .kv_info_w {
  width: 100%;
  position: absolute;
  left: 0;
  top: 13%;
  z-index: 3;
}
@media (max-width: 768px) {
  .kv_w .kv_info_w {
    top: 0;
  }
}
.kv_w .kv_photo_w {
  width: 52%;
  position: absolute;
  left: 25%;
  top: 5%;
  z-index: 2;
  overflow: hidden;
}
@media (max-width: 768px) {
  .kv_w .kv_photo_w {
    width: 100%;
    left: 0;
    top: 22.8%;
  }
}
.kv_w .temperature_w {
  width: 53%;
  position: absolute;
  left: 24%;
  bottom: 5%;
  z-index: 5;
}
@media (max-width: 768px) {
  .kv_w .temperature_w {
    width: 93.3%;
    left: 3.35%;
    top: 61.5%;
  }
}
.kv_w .temperature_w .temperature {
  position: relative;
}
.kv_w .temperature_w .temperature .kv_tiger {
  display: block;
  width: 26.1%;
  position: absolute;
  left: 10%;
  bottom: 65%;
  z-index: 2;
  will-change: transform;
  transform-origin: 50% 100%;
  transition: left 0.5s ease;
}
@media (max-width: 768px) {
  .kv_w .temperature_w .temperature .kv_tiger {
    width: 37.8%;
    left: 10%;
    bottom: 65%;
  }
}

.kv_pic {
  position: absolute;
  z-index: 4;
}

.p01 {
  width: 7.1%;
  left: 10.2%;
  top: 14.9%;
  animation: kv_p01 3s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p01 {
    display: none;
  }
}

.p02 {
  width: 4.4%;
  left: 16.8%;
  top: 58.7%;
  animation: kv_p02 0.25s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p02 {
    width: 9.7%;
    left: 78.8%;
    top: 19.5%;
  }
}

.p03 {
  width: 7.5%;
  left: 2.8%;
  top: 63.1%;
  opacity: 1;
  transform-origin: center bottom;
  animation: kv_p03 0.25s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p03 {
    width: 13.2%;
    left: 44.6%;
    top: 3.5%;
  }
}

.p04 {
  width: 8.5%;
  left: 88.3%;
  top: 20.5%;
  transform-origin: center;
  animation: kv_p04 1s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p04 {
    display: none;
  }
}

.p05 {
  width: 5.2%;
  left: 16.5%;
  top: 81.2%;
  transform-origin: center;
  animation: kv_p05 1s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p05 {
    display: none;
  }
}

.p06 {
  width: 5.2%;
  left: 77.9%;
  top: 82.8%;
  transform-origin: center;
  animation: kv_p06 1s ease-in-out infinite;
}
@media (max-width: 768px) {
  .p06 {
    display: none;
  }
}

@keyframes kv_p01 {
  0% {
    left: 18.2%;
  }
  45% {
    left: 5.2%;
    transform: rotateY(0deg);
  }
  50% {
    left: 5.2%;
    transform: rotateY(180deg);
  }
  95% {
    left: 18.2%;
    transform: rotateY(180deg);
  }
  100% {
    left: 18.2%;
    transform: rotateY(0deg);
  }
}
@keyframes kv_p02 {
  0% {
    top: 58.9%;
  }
  50% {
    top: 58.7%;
  }
  100% {
    top: 58.9%;
  }
}
@media (max-width: 768px) {
  @keyframes kv_p02 {
    0% {
      top: 19.5%;
    }
    50% {
      top: 18.5%;
    }
    100% {
      top: 19.5%;
    }
  }
}
@keyframes kv_p03 {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.9;
    transform: scale(1.02);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@media (max-width: 768px) {
  @keyframes kv_p03 {
    0% {
      opacity: 1;
      transform: scale(1);
    }
    50% {
      opacity: 0.9;
      transform: scale(1.1);
    }
    100% {
      opacity: 1;
      transform: scale(1);
    }
  }
}
@keyframes kv_p04 {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-8deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@keyframes kv_p05 {
  0% {
    top: 81.2%;
  }
  50% {
    top: 82.2%;
  }
  100% {
    top: 81.2%;
  }
}
@keyframes kv_p06 {
  0% {
    top: 82.8%;
  }
  50% {
    top: 81.8%;
  }
  100% {
    top: 82.8%;
  }
}
/*---------------*/
/* 粒子效果容器 */
.effect-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none; /* 讓滑鼠可以穿透此層，點擊到底下內容 */
  overflow: hidden;
  z-index: 6; /* 確保在背景圖之上，溫度計之下 */
}

/* 單一粒子 (楓葉或雪花) 的基本樣式 */
.particle {
  position: absolute;
  top: -150px; /* 初始位置在畫面上方 */
  will-change: transform, opacity; /* 告訴瀏覽器此元素將有動畫，進行優化 */
  animation-name: fall-and-tumble;
  animation-timing-function: linear;
  animation-iteration-count: infinite; /* 無限循環 */
}

.particle img {
  width: 100%;
  height: auto;
}

/* 定義下落與 3D 翻轉的動畫 */
@keyframes fall-and-tumble {
  from {
    transform: translateY(0) rotate(0deg);
    opacity: 1;
  }
  to {
    /* 讓粒子落到畫面底部再多一點點的地方，確保完全消失 */
    transform: translateY(calc(100vh + 150px)) rotate(360deg);
    opacity: 1;
  }
}
/*------------*/
#swiper-container1 > .swiper-wrapper .swiper-slide {
  height: auto;
  position: relative;
}

#swiper-container2 > .swiper-wrapper .swiper-slide {
  height: auto;
  position: relative;
}

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

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

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

.btn_buy_g {
  display: block;
  width: 10.9%;
  position: fixed;
  right: 1.5%;
  bottom: 2.5%;
  z-index: 8;
  transform-origin: center;
  animation: buy_ani 2s ease-in-out infinite;
}
@media (max-width: 992px) {
  .btn_buy_g {
    width: 8%;
  }
}
@media (max-width: 768px) {
  .btn_buy_g {
    width: 26%;
  }
}
.btn_buy_g .btn_airplane {
  width: 60.9%;
  position: absolute;
  left: 19%;
  top: -7.7%;
  z-index: 4;
  pointer-events: none;
}
.btn_buy_g .btn_dog {
  width: 60.9%;
  position: absolute;
  left: 19%;
  top: 50%;
  z-index: 4;
  pointer-events: none;
}
.btn_buy_g .btn_buy {
  position: relative;
  z-index: 3;
}
.btn_buy_g .btn_buy::after {
  width: 100%;
  height: 100%;
  display: block;
  content: "";
  background: #6ec1d3;
  border: 2px solid #fff;
  border-radius: 50%;
  position: absolute;
  left: 0%;
  top: 0%;
  z-index: -1;
  transition: all 0.25s ease-in-out;
}
.btn_buy_g .btn_buy:hover::after {
  background: #7ddbf0;
}
.btn_buy_g .btn_more {
  position: relative;
  margin-top: -28%;
  z-index: 2;
}
.btn_buy_g .btn_more::after {
  width: 100%;
  height: 100%;
  display: block;
  content: "";
  background: #ef845c;
  border: 2px solid #fff;
  border-radius: 50%;
  position: absolute;
  left: 0%;
  top: 0%;
  z-index: -1;
  transition: all 0.25s ease-in-out;
}
.btn_buy_g .btn_more:hover::after {
  background: #ff946d;
}

@keyframes buy_ani {
  0% {
    bottom: 2.5%;
  }
  50% {
    bottom: 5%;
  }
  100% {
    bottom: 2.5%;
  }
}
body {
  background: url(../images/kv/kv_bg.png) repeat-y center top;
  background-size: 100%;
}

/*---main---*/
main {
  display: block;
  width: 100%;
  position: relative;
  z-index: 5;
  overflow: hidden;
}

section {
  display: block;
  width: 100%;
  position: relative;
  margin: 0 auto;
  z-index: 2;
}

/*---s01-------------*/
#s01 {
  position: relative;
  background: url(../images/s01/cloud_bg.png) no-repeat center;
  background-size: 90%;
}

.box_w {
  width: 90%;
  position: relative;
  margin: 0% auto;
}
.box_w .time_w {
  width: 65.4%;
  margin: 0 auto 5%;
}
@media (max-width: 767px) {
  .box_w .time_w {
    width: 100%;
  }
}

/*---s02-------------*/
.autumn_w {
  position: relative;
  background: url(../images/s02/cloud_bg.png) no-repeat 28.5% 100%;
  background-size: 37.3%;
  overflow: hidden;
  z-index: 2;
}
.autumn_w h2 {
  width: 42.3%;
  position: relative;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .autumn_w h2 {
    width: 90%;
  }
}
.autumn_w h2 .fall_tiger {
  display: block;
  width: 40.6%;
  position: absolute;
  left: -38%;
  top: 30%;
  z-index: 2;
}
@media (max-width: 767px) {
  .autumn_w h2 .fall_tiger {
    width: 31%;
    left: -2%;
    top: 54%;
  }
}

.view_list {
  width: 80.6%;
  position: relative;
  margin: 5% auto 15%;
}

#swiper-container4 {
  overflow: hidden;
}

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

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
  left: -12%;
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  right: -12%;
}

.winter_w {
  position: relative;
  background: url(../images/s02/cloud_bg02.png) no-repeat 70% 100%;
  background-size: 37.6%;
  overflow: hidden;
  z-index: 3;
  margin-top: -10%;
  padding-top: 5%;
}
.winter_w h2 {
  width: 42.3%;
  position: relative;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .winter_w h2 {
    width: 90%;
  }
}
.winter_w h2 .winter_tiger {
  width: 33.9%;
  position: absolute;
  right: -20%;
  bottom: 0;
  z-index: 2;
}
@media (max-width: 767px) {
  .winter_w h2 .winter_tiger {
    width: 30%;
    right: -6%;
  }
}

.view_list02 {
  width: 80.6%;
  position: relative;
  margin: 5% auto 20%;
}

#swiper-container5 {
  overflow: hidden;
}

#swiper-container6 {
  overflow: hidden;
}

/*---s03-------------*/
.food_w {
  position: relative;
  overflow: auto;
  z-index: 2;
  margin-top: -15%;
}
.food_w h2 {
  width: 41.7%;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .food_w h2 {
    width: 90%;
  }
}

#swiper-container7 {
  overflow: hidden;
}

#swiper-container8 {
  overflow: hidden;
}

.view_list03 {
  width: 80.6%;
  position: relative;
  margin: 5% auto 0%;
}

.view_list032 {
  width: 80.6%;
  position: relative;
  margin: 5% auto 0%;
}

/*---s04-------------*/
#s04 {
  position: relative;
}

.traffic_w {
  width: 77%;
  position: relative;
  margin: 0% auto 10%;
}
@media (max-width: 767px) {
  .traffic_w {
    width: 100%;
    margin: 0% auto 10%;
  }
}
.traffic_w .btn_bus {
  position: absolute;
  width: 20%;
  bottom: 8%;
  left: 14%;
  z-index: 5;
}
@media (max-width: 767px) {
  .traffic_w .btn_bus {
    width: 40%;
    bottom: 35.5%;
    left: 19%;
  }
}

/*---popup / 注意事項---*/
/*---popup---*/
.modally {
  max-width: 90%;
  width: 51.9%;
  background: #fff;
  border-radius: 30px;
  padding: 4px;
  background: #3e3a39;
}
@media (max-width: 991px) {
  .modally {
    width: 90%;
  }
}

.modally-content {
  background: #fff;
  border-radius: 30px;
  padding-top: 5%;
}
@media (max-width: 991px) {
  .modally-content {
    padding-top: 10%;
  }
}

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

.modally-wrap .modally-underlay {
  background: rgba(255, 173, 39, 0.9);
}

/*popup / 使用規範*/
.rules-w {
  width: 90%;
  margin: 0% auto;
  padding: 5% 0;
  position: relative;
}
.rules-w h5 {
  display: inline;
  font-size: 1.05vw;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .rules-w h5 {
    font-size: 3.05vw;
  }
}
.rules-w h5 img {
  width: 1.05vw;
  display: inline;
  vertical-align: middle;
}
@media (max-width: 768px) {
  .rules-w h5 img {
    width: 3vw;
  }
}

ul.ps_text {
  list-style-type: none;
  display: flex;
  flex-flow: column wrap;
  font-size: 1vw;
  line-height: 1.5;
  margin: 0 0 5%;
}
ul.ps_text li {
  width: 95%;
  list-style-type: decimal-leading-zero;
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  color: #333;
  margin: 1% 0 1% 5%;
}
@media (max-width: 991px) {
  ul.ps_text li {
    width: 88%;
    margin: 1% 0 1% 12%;
    font-size: 3vw;
  }
}
ul.ps_text li a {
  font-size: 1vw;
  color: #ea5513;
  text-decoration: underline;
}
@media (max-width: 991px) {
  ul.ps_text li a {
    font-size: 3vw;
  }
}

/*-------------------------------------------------------------*/
.overlay {
  width: 25%;
  background: rgba(138, 149, 150, 0.9);
}
@media (max-width: 768px) {
  .overlay {
    width: 100%;
  }
}

.overlay nav {
  top: 0vh;
  height: 95vh;
}
.overlay nav ul {
  display: block;
  width: 80%;
  height: 80%;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  padding: 10%;
}
.overlay nav ul li {
  width: 100%;
  display: flex;
}
@media (max-width: 992px) {
  .overlay nav ul li span {
    font-size: 2vw;
    text-align: right !important;
  }
}
@media (max-width: 768px) {
  .overlay nav ul li span {
    font-size: 5vw;
    text-align: left !important;
  }
}
.overlay nav ul li a div {
  display: flex;
  width: 100%;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 2;
  justify-content: flex-start;
  align-items: center;
  padding: 10px;
}
.overlay nav ul li a div span {
  width: 15vw;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 2;
  color: #fff;
}
.overlay nav ul li a div p {
  font-size: 5vw;
  font-weight: 600;
}

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

button.menu_m {
  display: none;
  position: relative;
  top: 0%;
  right: 0%;
  width: 11.2%;
  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: 768px) {
  button.menu_m {
    display: block;
    width: 11.2%;
    height: auto;
  }
}/*# sourceMappingURL=style.css.map */