@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 Serif TC", "Noto Sans TC", serif, "微軟正黑體", "新細明體", "細明體";
  font-size: 16px;
  line-height: 25px;
  color: #555;
  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.5vw;
  line-height: 1.8;
  color: #707070;
  font-weight: 300;
}
@media (max-width: 992px) {
  p {
    font-size: 2.25vw;
  }
}
@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---*/
.wrapper {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.wrapper header {
  width: 98%;
  position: relative;
  background: #fff;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  padding: 0.25% 1%;
}
@media (max-width: 768px) {
  .wrapper header {
    padding: 1% 1%;
  }
}
.wrapper header::before {
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  background: url(../images/main_bg.png) repeat top left;
  background-size: 100%;
}
@media (max-width: 992px) {
  .wrapper header::before {
    background-size: 150%;
  }
}
@media (max-width: 768px) {
  .wrapper header::before {
    background-size: 250%;
  }
}
.wrapper header .logo01 {
  width: 13.7%;
  order: 1;
  z-index: 2;
}
@media (max-width: 768px) {
  .wrapper header .logo01 {
    width: 27%;
  }
}
.wrapper header .logo_jp_box {
  display: flex;
  width: 22.3%;
  order: 3;
  z-index: 2;
}
@media (max-width: 768px) {
  .wrapper header .logo_jp_box {
    width: 52.3%;
  }
}
.wrapper header .logo_jp_box .logo_jp {
  width: 50%;
}
.wrapper header nav {
  width: 60%;
  position: relative;
  z-index: 2;
  order: 2;
}
@media (max-width: 768px) {
  .wrapper header nav {
    display: none;
  }
}
.wrapper header nav ul {
  list-style-type: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: center;
}
.wrapper header nav ul li {
  width: auto;
  margin: 0 2%;
}
.wrapper header nav ul li a {
  text-decoration: none;
}
.wrapper header nav ul li a img {
  display: inline-block;
  width: 1.25vw;
  vertical-align: middle;
}
@media (max-width: 992px) {
  .wrapper header nav ul li a img {
    width: 2vw;
  }
}
.wrapper header nav ul li a span {
  font-family: Arial, "Arial Black", "Noto Sans TC", "微軟正黑體";
  display: inline;
  font-size: 1.15vw;
  color: #555;
  vertical-align: middle;
  transition: all 0.25s linear;
}
@media (max-width: 992px) {
  .wrapper header nav ul li a span {
    font-size: 1.75vw;
  }
}
.wrapper header nav ul li a:hover span {
  color: #c6a863;
}
.wrapper .kv_banner {
  width: 100%;
  position: relative;
  overflow: hidden;
}

.banner_info_top01 {
  top: 32%;
}
@media (max-width: 768px) {
  .banner_info_top01 {
    top: 40%;
  }
}

.banner_info_top02 {
  top: 15%;
}

a {
  text-decoration: none;
}

.banner_info_w1 {
  width: 42.7%;
}
@media (min-width: 769px) and (max-width: 991px) {
  .banner_info_w1 {
    width: 85%;
  }
}
@media (max-width: 768px) {
  .banner_info_w1 {
    width: 100%;
  }
}

.banner_info {
  display: block;
  position: absolute;
  left: 6.5%;
}
.banner_info .airplane {
  width: 36.5%;
  margin: -5% 0 0 -5%;
}
.banner_info .talk {
  width: 26.8%;
  position: absolute;
  left: -8%;
  top: -30%;
  z-index: 2;
  transform-origin: 90% 90%;
  animation: talk 1s ease-in-out infinite;
}
.banner_info h2 {
  width: 65%;
}
.banner_info h3 {
  font-size: 4rem;
  color: #fff;
  line-height: 1.25;
  font-weight: bold;
  width: 73.1%;
  padding: 1% 0 2%;
}
.banner_info h4 {
  font-size: 1.5vw;
  color: #fff;
  line-height: 1.25;
  padding: 1% 0;
}
.banner_info h4.banner_en {
  width: 34.9%;
  padding: 1% 0;
}
.banner_info p {
  font-size: 1.15vw;
  font-weight: 400;
  color: #fff;
  padding: 2% 0;
  border-top: 1px solid #fff;
}
@media (max-width: 768px) {
  .banner_info p {
    font-size: 5vw;
  }
}
.banner_info .map {
  width: 109%;
  position: absolute;
  left: -25%;
  top: -95%;
  z-index: -1;
}
.banner_info .btn_more {
  width: 41.2%;
  max-width: 260px;
  position: relative;
  margin-top: 2%;
}
.banner_info .btn_more::before {
  display: block;
  content: "";
  background: #fff;
  width: 50px;
  height: 50px;
  position: absolute;
  left: 16%;
  top: 16%;
  z-index: 2;
  border-radius: 100px;
  opacity: 0;
  filter: blur(8px);
  transform-origin: center;
  pointer-events: none;
}
.banner_info .btn_more:hover::before {
  animation: btn_strategy 0.25s ease-in 0.1s forwards;
}

@keyframes btn_strategy {
  0% {
    transform: scale(0.15);
    opacity: 0;
  }
  60% {
    transform: scale(1.5);
    opacity: 0.9;
  }
  90% {
    transform: scale(3);
    opacity: 0.9;
  }
  100% {
    transform: scale(3.5);
    opacity: 0;
  }
}
@keyframes talk {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-5deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
.kv_number {
  display: inline-block;
  width: 5%;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 9;
}
.kv_number .swiper-wrapper .swiper-slide {
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
}

.banner_info {
  opacity: 0;
}

#swiper-container2 > .swiper-wrapper > .swiper-slide-active > .banner_info {
  animation: banner_info 0.5s ease-in-out 1s forwards;
}

@keyframes banner_info {
  0% {
    left: 10%;
    opacity: 0;
  }
  100% {
    left: 6.5%;
    opacity: 1;
  }
}
@media (max-width: 768px) {
  @keyframes banner_info {
    0% {
      left: 20%;
      opacity: 0;
    }
    100% {
      left: 10%;
      opacity: 1;
    }
  }
}
.swiper-pagination-bullet {
  width: 15px;
  height: 15px;
  margin: 5px;
  background: transparent;
  border: 1px solid #fff;
  opacity: 1;
  margin-top: 2%;
}

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

/*--kv / 小圖輪播--*/
.kv_description {
  width: 48.4%;
  position: absolute;
  bottom: 26%;
  right: -5%;
  z-index: 2;
  overflow: hidden;
}
.kv_description .swiper-wrapper .swiper-slide {
  padding-bottom: 2%;
  box-sizing: border-box;
}
.kv_description .swiper-wrapper .swiper-slide img {
  filter: drop-shadow(8px 8px 7px rgba(0, 0, 0, 0.75));
}
@media (min-width: 768px) and (max-width: 991px) {
  .kv_description {
    display: none;
  }
}
@media (max-width: 767px) {
  .kv_description {
    display: none;
  }
}

.banner-s-info {
  display: inline;
  width: 100%;
  position: absolute;
  left: 0%;
  top: 0;
  padding: 5% 17% 10%;
  box-sizing: border-box;
  z-index: 2;
}
.banner-s-info h4 {
  font-family: Arial, "Arial Black", "Noto Sans TC", serif, "微軟正黑體";
  font-size: 0.75vw;
  font-weight: 600;
  color: #707070;
  line-height: 1.5;
  letter-spacing: 0;
}

.arrow_box {
  display: flex;
  width: 100%;
  flex-direction: row;
  justify-content: center;
}

.swiper-button-prev {
  background-image: url(../images/kv/arrow_prv.svg);
}

.swiper-button-next {
  background-image: url(../images/kv/arrow_next.svg);
}

.swiper-button {
  width: 60px;
  height: 60px;
  background-size: 100%;
  position: relative;
  margin: 20px;
  left: 0;
}

.swiper-wrapper {
  align-items: stretch;
}

.swiper-slide {
  height: auto;
}

.btn_buy {
  display: block;
  width: 7%;
  position: fixed;
  right: 1%;
  bottom: 3%;
  z-index: 8;
  transform-origin: center;
  animation: buy_ani 1s ease-in-out infinite;
}
@media (max-width: 992px) {
  .btn_buy {
    width: 8%;
  }
}
@media (max-width: 768px) {
  .btn_buy {
    width: 15%;
  }
}

@keyframes buy_ani {
  0% {
    margin-bottom: 0;
  }
  50% {
    margin-bottom: 1%;
  }
  100% {
    margin-bottom: 0;
  }
}
/*---main---*/
main {
  position: relative;
  background: #9bbac6;
  margin-top: -2px;
  z-index: 2;
}

section {
  position: relative;
  background: url(../images/main_bg.png) repeat top left;
  background-size: 100%;
  overflow: hidden;
}
@media (max-width: 992px) {
  section {
    background-size: 150%;
  }
}
@media (max-width: 768px) {
  section {
    background-size: 250%;
  }
}

#section_space {
  height: 80px;
}

/*---s00---*/
.ig_photo_list {
  width: 68.8%;
  margin: 5% auto 0;
}
@media (max-width: 992px) {
  .ig_photo_list {
    width: 78.8%;
  }
}
@media (max-width: 768px) {
  .ig_photo_list {
    width: 90%;
    margin: 5% auto 5%;
  }
}
.ig_photo_list ul.ig_sphoto {
  list-style-type: none;
  width: 100%;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: flex-start;
}
@media (max-width: 768px) {
  .ig_photo_list ul.ig_sphoto {
    justify-content: center;
  }
}
.ig_photo_list ul.ig_sphoto li {
  width: 12.3%;
  margin: 2% 0 0 1.1%;
}
@media (max-width: 768px) {
  .ig_photo_list ul.ig_sphoto li {
    width: 23%;
  }
}
.ig_photo_list ul.ig_sphoto li .ig_sp {
  width: 100%;
}
.ig_photo_list ul.ig_sphoto li span {
  font-family: "Noto Serif TC";
  font-size: 1.15vw;
  font-weight: 700;
  line-height: 2;
  color: #333;
  text-align: center;
}
@media (max-width: 992px) {
  .ig_photo_list ul.ig_sphoto li span {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .ig_photo_list ul.ig_sphoto li span {
    font-size: 3.5vw;
  }
}
.ig_photo_list ul.ig_sphoto li span span.ps {
  font-size: 0.8vw;
  line-height: 1;
}
@media (max-width: 768px) {
  .ig_photo_list ul.ig_sphoto li span span.ps {
    font-size: 2vw;
    line-height: 1.5;
  }
}

/*---s03---*/
.ig_w {
  width: 76%;
  margin: 5% auto;
}
@media (max-width: 992px) {
  .ig_w {
    width: 78.8%;
  }
}
@media (max-width: 768px) {
  .ig_w {
    width: 90%;
  }
}
.ig_w h2 {
  width: 35.5%;
  margin: 5% auto 0%;
}
@media (max-width: 768px) {
  .ig_w h2 {
    width: 60%;
  }
}
.ig_w .ig_infobox {
  width: 75.6%;
  position: relative;
  margin: 0 auto;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 992px) {
  .ig_w .ig_infobox {
    width: 90%;
  }
}
@media (max-width: 768px) {
  .ig_w .ig_infobox {
    width: 100%;
  }
}
.ig_w .ig_infobox .tigerair_p {
  width: 28.3%;
}
.ig_w .ig_infobox .tigerair_p img {
  width: 59.5%;
  float: right;
}
@media (max-width: 768px) {
  .ig_w .ig_infobox .tigerair_p img {
    width: 100%;
  }
}
.ig_w .ig_infobox .ig_info {
  width: 68.7%;
  padding: 1.5%;
}
.ig_w .ig_infobox .ig_info h3 {
  width: 100%;
  font-size: 2vw;
  font-weight: 600;
  line-height: 1.25;
  color: #fff;
  margin: 1% 0;
}
@media (max-width: 768px) {
  .ig_w .ig_infobox .ig_info h3 {
    font-size: 4vw;
  }
}
.ig_w .ig_infobox .ig_info p {
  font-weight: 400;
  color: #fff;
  line-height: 1.5;
  text-align: justify;
}
@media (max-width: 768px) {
  .ig_w .ig_infobox .ig_info p {
    font-size: 3vw;
  }
}
.ig_w .ig_tour {
  width: 75.6%;
  position: relative;
  margin: 0 auto;
}
@media (max-width: 992px) {
  .ig_w .ig_tour {
    width: 100%;
  }
}
@media (max-width: 768px) {
  .ig_w .ig_tour {
    width: 100%;
  }
}
.ig_w .ig_tour ul {
  list-style-type: none;
}
.ig_w .ig_tour ul li {
  position: relative;
  margin: 2.5% 0;
}
.ig_w .ig_tour ul li:nth-child(even) .ig_tour_box .ig_photo {
  order: 1;
}
.ig_w .ig_tour ul li:nth-child(even) .ig_tour_box .ig_tour_info {
  order: 2;
}
@media (max-width: 768px) {
  .ig_w .ig_tour ul li:nth-child(even) .ig_tour_box .ig_tour_info {
    margin: 5% 0 10%;
  }
}
@media (max-width: 768px) {
  .ig_w .ig_tour ul li {
    margin: 10% 0;
  }
}

.ig_tour_box {
  position: relative;
  width: 90%;
  background: #fff;
  box-shadow: 5px 5px 5px #555;
  padding: 0 5%;
  overflow: hidden;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 768px) {
  .ig_tour_box {
    flex-flow: column wrap;
  }
}
.ig_tour_box .ig_photo {
  width: 42.8%;
  order: 2;
}
@media (max-width: 768px) {
  .ig_tour_box .ig_photo {
    width: 90%;
    order: 1;
    margin-top: 10%;
  }
}
.ig_tour_box .ig_tour_info {
  width: 53.2%;
  padding: 0.5% 2%;
  order: 1;
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info {
    width: 86%;
    order: 2;
    margin: 5% 0 10%;
  }
}
.ig_tour_box .ig_tour_info .ig_title {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ig_tour_box .ig_tour_info .ig_title h3 {
  display: inline-block;
  width: auto;
  font-size: 2.5vw;
  font-weight: 600;
  line-height: 1.5;
  padding-left: 2vw;
  position: relative;
}
@media (max-width: 992px) {
  .ig_tour_box .ig_tour_info .ig_title h3 {
    font-size: 3.5vw;
    padding-left: 4vw;
  }
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info .ig_title h3 {
    font-size: 5vw;
    padding-left: 5vw;
  }
}
.ig_tour_box .ig_tour_info .ig_title h3::before {
  display: block;
  content: "";
  width: 2vw;
  height: 100%;
  line-height: 1.5;
  position: absolute;
  left: 0;
  top: 15%;
  z-index: 2;
  background: url(../images/s03/title_pic.png) no-repeat;
  background-size: 100%;
}
@media (max-width: 992px) {
  .ig_tour_box .ig_tour_info .ig_title h3::before {
    width: 3vw;
  }
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info .ig_title h3::before {
    width: 4vw;
  }
}
.ig_tour_box .ig_tour_info .ig_title h3 span {
  font-size: 1.15vw;
  font-weight: 600;
  line-height: 1;
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info .ig_title h3 span {
    font-size: 2vw;
  }
}
.ig_tour_box .ig_tour_info .ig_title .btn_ig {
  display: inline-block;
  width: auto;
  font-size: 1.15vw;
  font-weight: 400;
  color: #fff;
  background: #c6a863;
  border-radius: 50px;
  padding: 0.25vw 1vw;
  position: relative;
  overflow: hidden;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info .ig_title .btn_ig {
    padding: 0.25vw 2vw;
  }
}
.ig_tour_box .ig_tour_info .ig_title .btn_ig::before {
  display: block;
  content: "";
  width: 35%;
  height: 100%;
  /* Permalink - use to edit and share this gradient. 固定鏈接 - 用於編輯和分享此漸變： https://colorzilla.com/gradient-editor/#ffffff+0,ffffff+36,ffffff+61,ffffff+100&0+0,0.7+36,0.7+61,0+100 */
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.7) 36%, rgba(255, 255, 255, 0.7) 61%, rgba(255, 255, 255, 0) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  position: absolute;
  left: -35%;
  top: 0;
  z-index: 2;
  transform: skewX(-25deg);
  transition: all 0.25s linear;
  mix-blend-mode: lighten;
}
.ig_tour_box .ig_tour_info .ig_title .btn_ig:hover::before {
  left: 135%;
}
.ig_tour_box .ig_tour_info .ig_title .btn_ig a {
  text-decoration: none;
}
.ig_tour_box .ig_tour_info .ig_title .btn_ig a span {
  display: inline-block;
  width: auto;
  font-size: 1.15vw;
  font-weight: 400;
  color: #fff;
}
@media (max-width: 992px) {
  .ig_tour_box .ig_tour_info .ig_title .btn_ig a span {
    font-size: 1.75vw;
  }
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info .ig_title .btn_ig a span {
    font-size: 4vw;
  }
}
.ig_tour_box .ig_tour_info p {
  font-weight: 600;
  color: #c6a863;
  line-height: 1.5;
  padding-left: 2vw;
  margin-top: 5%;
}
@media (max-width: 768px) {
  .ig_tour_box .ig_tour_info p {
    font-size: 4vw;
    margin-top: 5%;
  }
}

/*---s01---*/
.prd_w {
  width: 76%;
  position: relative;
  margin: 5% auto;
  overflow: hidden;
}
@media (max-width: 768px) {
  .prd_w {
    width: 90%;
  }
}
.prd_w h2 {
  width: 35.5%;
  margin: 0 auto 5%;
}
@media (max-width: 768px) {
  .prd_w h2 {
    width: 60%;
  }
}
.prd_w .prd_box {
  position: relative;
}
.prd_w .prd_box .prd_g {
  width: 100%;
  position: relative;
  margin: 0 auto;
}

.prd_content_box {
  position: relative;
  margin: 0 0 15%;
}
.prd_content_box .prd_ig {
  position: relative;
  overflow: hidden;
  filter: drop-shadow(8px 8px 7px rgba(0, 0, 0, 0.75));
}
.prd_content_box .prd_ig .prd_photo {
  position: absolute;
  left: 0;
  top: 11.5%;
  z-index: -1;
  transition: all 2.5s ease-in-out;
}
.prd_content_box .prd_ig:hover .prd_photo {
  transform: scale(1.2);
}
.prd_content_box .prd_info {
  margin: 15% auto 0;
  position: relative;
  width: 100%;
  text-align: center;
}
.prd_content_box .prd_info h3 {
  display: inline-block;
  width: auto;
  font-size: 2vw;
  font-weight: 600;
  position: relative;
  color: #fff;
  line-height: 1.5;
  margin-bottom: 2.5%;
}
@media (max-width: 992px) {
  .prd_content_box .prd_info h3 {
    font-size: 2.25vw;
  }
}
@media (max-width: 768px) {
  .prd_content_box .prd_info h3 {
    font-size: 5vw;
  }
}
.prd_content_box .prd_info h3::before {
  width: 1.5vw;
  height: 2px;
  content: "";
  background: #fff;
  position: absolute;
  left: -1.75vw;
  top: 50%;
  z-index: 2;
}
@media (max-width: 768px) {
  .prd_content_box .prd_info h3::before {
    width: 3vw;
    left: -3vw;
  }
}
.prd_content_box .prd_info h3::after {
  width: 1.5vw;
  height: 2px;
  content: "";
  background: #fff;
  position: absolute;
  right: -1.75vw;
  top: 50%;
  z-index: 2;
}
@media (max-width: 768px) {
  .prd_content_box .prd_info h3::after {
    width: 3vw;
    right: -3vw;
  }
}
.prd_content_box .prd_info .prd_text {
  font-family: Arial, "Arial Black", "Noto Sans TC";
  font-size: 1.25vw;
  font-weight: 600;
  line-height: 1.5;
  color: #333;
}
@media (max-width: 992px) {
  .prd_content_box .prd_info .prd_text {
    font-size: 1.5vw;
  }
}
@media (max-width: 768px) {
  .prd_content_box .prd_info .prd_text {
    font-size: 3.5vw;
  }
}
.prd_content_box .prd_info .prd_text span {
  font-size: 1.25vw;
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
}
.prd_content_box .prd_info .twd {
  display: inline-block;
  font-family: Arial, "Arial Black", "Noto Sans TC";
  font-size: 1vw;
  margin: 5% auto;
  color: #fff;
}
@media (max-width: 992px) {
  .prd_content_box .prd_info .twd {
    font-size: 1.25vw;
  }
}
@media (max-width: 768px) {
  .prd_content_box .prd_info .twd {
    font-size: 3vw;
  }
}
.prd_content_box .prd_info .twd span {
  display: inline;
  font-size: 2.5vw;
  font-weight: 500;
  color: #fff100;
}
@media (max-width: 768px) {
  .prd_content_box .prd_info .twd span {
    font-size: 5vw;
  }
}
.prd_content_box .prd_info .btn_prd {
  display: inline-block;
  width: auto;
  margin: 5% auto 0;
}
.prd_content_box .prd_info .btn_prd a {
  text-decoration: none;
}
.prd_content_box .prd_info .btn_prd a span {
  font-family: Arial, "Arial Black", "Noto Sans TC";
  display: inline-block;
  width: auto;
  font-size: 1.05vw;
  font-weight: 400;
  color: #fff;
  padding: 0.5vw 1vw;
  background: #557d87;
  border-radius: 50px;
  transition: all 0.25s ease-in-out;
}
@media (max-width: 992px) {
  .prd_content_box .prd_info .btn_prd a span {
    font-size: 1.75vw;
    padding: 0.5vw 2vw;
  }
}
@media (max-width: 768px) {
  .prd_content_box .prd_info .btn_prd a span {
    font-size: 4vw;
    padding: 1vw 3vw;
  }
}
.prd_content_box .prd_info .btn_prd a:hover span {
  padding: 0.5vw 2vw;
}
@media (max-width: 992px) {
  .prd_content_box .prd_info .btn_prd a:hover span {
    padding: 0.5vw 4vw;
  }
}
@media (max-width: 768px) {
  .prd_content_box .prd_info .btn_prd a:hover span {
    padding: 1vw 6vw;
  }
}

#swiper-container4 > .swiper-wrapper {
  justify-content: center;
}
@media (max-width: 768px) {
  #swiper-container4 > .swiper-wrapper {
    justify-content: flex-start;
  }
}

/*---s02---*/
#s02 {
  position: relative;
  background: #efefef;
}
#s02::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  background: url(../images/main_bg.png) repeat top left;
  background-size: 100%;
  mix-blend-mode: multiply;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}
@media (max-width: 992px) {
  #s02::before {
    background-size: 150%;
  }
}
@media (max-width: 768px) {
  #s02::before {
    background-size: 250%;
  }
}
#s02 .city_bg {
  position: absolute;
  bottom: 0;
  z-index: 2;
}

.map_w {
  width: 76%;
  position: relative;
  margin: 5% auto;
  z-index: 3;
}
@media (max-width: 768px) {
  .map_w {
    width: 90%;
  }
}
.map_w .map_en_box {
  width: 34.6%;
  margin: 0 auto 0.5%;
}
@media (max-width: 768px) {
  .map_w .map_en_box {
    width: 50%;
  }
}
.map_w h2 {
  width: 46.4%;
  margin: 0 auto 5%;
}
@media (max-width: 768px) {
  .map_w h2 {
    width: 70%;
  }
}
.map_w .map_airplane {
  width: 15.9%;
  position: absolute;
  left: 60%;
  top: 0;
  z-index: 5;
  pointer-events: none;
}
@media (max-width: 768px) {
  .map_w .map_airplane {
    width: 25.9%;
    left: 70%;
  }
}
.map_w .map_box {
  width: 98.7%;
  position: relative;
  margin: 0 auto;
}

/*---選項卡---*/
.tabs {
  display: flex;
  flex-wrap: wrap;
}

.tabs label {
  order: 1;
  display: block;
  /*padding: 1rem 2rem;
  margin-right: 0.2rem;*/
  cursor: pointer;
  /*background: #90CAF9;*/
  /* background: url("images/tab/tab_btn_bg.png"); */
  background-size: 100%;
  font-weight: bold;
  transition: background ease 0.2s;
  /* width:33.2%;
  margin-right: 0.1%;	*/
  margin: 2%;
  position: absolute;
  top: 0;
  z-index: 3;
}

.tabs .tab {
  order: 99;
  flex-grow: 1;
  width: 100%;
  display: none;
  /*padding: 1rem;
  background: #fafafa;
  margin:0.2% 0 0.5% 0;*/
}

.tabs input[type=radio] {
  position: absolute;
  opacity: 0;
}

.tabs input[type=radio]:checked + label.tab_btn01 { /*background: #fafafa;*/
  background: url("../images/s02/btn01_on.png");
  background-size: 100%;
}

.tabs input[type=radio]:checked + label.tab_btn02 { /*background: #fafafa;*/
  background: url("../images/s02/btn02_on.png");
  background-size: 100%;
}

.tabs input[type=radio]:checked + label.tab_btn03 { /*background: #fafafa;*/
  background: url("../images/s02/btn03_on.png");
  background-size: 100%;
}

.tabs input[type=radio]:checked + label + .tab {
  display: block;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .tabs input[type=radio]:checked + label + .tab {
    margin: 10% auto 0;
  }
}

/*--------------*/
.tabs_box {
  display: block;
  width: 100%;
  margin: 2% auto;
}

.tab_btn01 {
  width: 17.9%;
  background: url("../images/s02/btn01_off.png");
  background-size: 100%;
  left: 0;
}
@media (max-width: 768px) {
  .tab_btn01 {
    width: 27.9%;
  }
}

.tab_btn02 {
  width: 17.9%;
  background: url("../images/s02/btn02_off.png");
  background-size: 100%;
  left: 19%;
}
@media (max-width: 768px) {
  .tab_btn02 {
    width: 27.9%;
    left: 29%;
  }
}

.tab_btn03 {
  width: 17.9%;
  background: url("../images/s02/btn03_off.png");
  background-size: 100%;
  left: 38%;
}
@media (max-width: 768px) {
  .tab_btn03 {
    width: 27.9%;
    left: 48%;
  }
}

.tabs {
  display: flex;
  justify-content: center;
}

/*-------------------------------------------------------------*/
.overlay {
  width: 100%;
  background: rgba(0, 0, 0, 0.75);
}

.overlay nav {
  top: 0vh;
  height: 100vh;
}
.overlay nav ul {
  display: block;
  width: 80%;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  padding: 0 10%;
}
.overlay nav ul li {
  width: 100%;
  display: flex;
  border-left: none;
  border-right: none;
  margin: 1vh auto;
}
.overlay nav ul li div {
  display: flex;
  width: auto;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 2;
  justify-content: center;
  align-items: center;
  padding: 10px;
}
.overlay nav ul li div img {
  display: inline-block;
  width: 6vw;
  margin-right: 2vw;
}
.overlay nav ul li div span {
  display: inline;
  width: auto;
  font-size: 6vw;
  font-weight: 400;
  line-height: 2;
  color: #fff;
  transition: all 0.5s ease-in-out;
}
.overlay nav ul li div span:hover {
  color: #c6a863;
}
.overlay nav ul 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: none;
  position: relative;
  top: 0%;
  right: 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: 10%;
    height: auto;
  }
}/*# sourceMappingURL=style.css.map */