@import url(//fonts.googleapis.com/earlyaccess/notosanstc.css);
body {
  min-width: 1200px;
  color: #333;
  font-family:"Century Gothic", Arial, "Microsoft JhengHei", "sans-serif";
  line-height: 1.4;
}
a {
  text-decoration: none;
  display: inline-block;
}
:focus {
  outline: none;
}
i {
  font-style: normal;
}
* {
  box-sizing: border-box;
}
.header,
.footer {
  text-align: center;
  background: #fff;
  line-height: 0;
}
.display_pc {
  display: block;
}
.display_m {
  display: none;
}

/**main_wrapper**/
.main_wrapper {
  margin: auto;
  position: relative;
  width: 100%;
  overflow: hidden;
  background: url(../images/kv_bg.png) no-repeat top center,
    url(../images/main_bg.png) repeat center;
}

/**kv_wrapper**/
.kv_wrapper {
  overflow: hidden;
  position: relative;
}
/**kv_container**/
.kv_container {
  position: relative;
  margin: auto;
  max-width: 1200px;
  height: 570px;
  display: flex;
  align-items: center;
  justify-content: center;
}
/**kv_slogan**/
.kv_slogan {
  pointer-events: none;
}
.kv_logo {
  position: absolute;
  top: 4%;
  left: 7%;
  z-index: 999;
}
.kv_logo a img {
  transition: 0.3s all ease-in-out;
}
@media (hover: hover) {
  .kv_logo a img:hover {
    transform: translateY(-5%);
  }
}

.animate__fadeInDown {
  --animate-duration: 2s;
}
.animate__flipInX {
  --animate-duration: 2s;
}
.animate__jackInTheBox {
  --animate-duration: 3s;
  --animate-delay: 1s;
}
.item {
  --animate-duration: 2s;
}

/*event*/
.event_wrapper {
  position: relative;
  width: 100%;
  z-index: 900;
}
.event_container {
  max-width: 822px;
  height: 180px;
  margin: 0 auto;
  background: url(../images/bg_map.png) no-repeat center bottom;
  background-size: contain;
}
.event {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.event .item {
  margin-top: -80px;
}

@media (hover: hover) {
  .event a {
    transition: all 0.4s;
    cursor: pointer;
  }
  .event a:hover {
    transform: translateY(-8px);
    filter: brightness(1.2);
  }
}

/**prod**/
.prod_wrapper {
  position: relative;
}
.prod_container {
  position: relative;
  z-index: 100;
  /**overflow: hidden;**/
}
.ProductList {
  position: relative;
  z-index: 500;
  margin: auto;
  max-width: 1100px;
  display: flex;
  flex-direction: column;
}
.group {
  position: relative;
  padding-bottom: 60px;
  max-width: 1020px;
  margin: 0 auto;
  width: 96%;
}
.group:before {
  content: "";
  position: absolute;
  top: 0;
  left: -60px;
  right: -60px;
  bottom: 0;
  margin: auto;
  background-image: url("../images/border_bd.png");
  background-repeat: repeat-y;
  background-position: center;
  z-index: -2;
}

/**群組表頭設定**/

#group_9 {
  padding-top: 60px;
  margin-bottom: 60px;
}

#group_9:after {
  content: "";
  position: absolute;
  left: -60px;
  right: -60px;
  height: 60px;
  bottom: 0;
  background-image: url("../images/border_ft.png");
  background-position: bottom;
}
#group_9:before {
  bottom: 60px; 
  background-image: url("../images/border_hd.png");
  background-position: top;
  background-repeat: no-repeat;
}

/**群組表尾設定**/
#group_5:before,
#group_7:before {
  bottom: 60px; /**與群組表尾高度一樣**/
}
#group_5:after,
#group_7:after {
  content: "";
  position: absolute;
  left: -60px;
  right: -60px;
  height: 60px; /**群組表尾高度**/
  bottom: 0;
  background-image: url("../images/border_ft.png");
  background-repeat: no-repeat;
  background-position: bottom;
}
#group_8:before {
  background-image: url("../images/border_ft.png");
  background-position: bottom;
  background-repeat: no-repeat;
}
#group_1,
#group_2,
#group_3,
#group_4,
#group_5 {
  order: 1;
}
#group_6,
#group_7 {
  order: 3;
}
#group_8,
#group_9 {
  order: 5;
}
.map_item {
  height: 738px;
  position: relative;
}
.map_item:after {
  content: "";
  position: absolute;
  left: -60px;
  right: -60px;
  bottom: 0;
  top: 0;
  z-index: -1;
  background-image: url("../images/border_hd.png");
  background-repeat: no-repeat;
  background-position: center top;
}
.map_jp {
  order: 0;
  background: url("../images/img_map_jp.png") no-repeat center;
}
.map_kr {
  order: 2;
  background: url("../images/img_map_kr.png") no-repeat center;
}
.map_tw {
  order: 4;
  background: url("../images/img_map_tw.png") no-repeat center;
}
.title_wrapper {
  position: relative;
  background: url(../images/bg_title.png) no-repeat center;
  height: 100px;
  background-size: contain;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  max-width: 635px;
  margin: 0 auto;
  gap: 1em;
}

.title_wrapper .title {
  display: block;
  font-size: 40px;
  font-weight: 500;
  position: relative;
  text-align: center;
  color: #e56098;
}
.title_wrapper .more_link {
  background-color: #792b8e;
  border-radius: 20px;
  padding: 5px 10px;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  width: max-content;
}
@media (hover: hover) {
  .title_wrapper .more_link:hover {
    background-color: #7967d5;
  }
}
.content_wrapper {
  display: flex;
}

.tab_wrapper {
  width: 100%;
  display: flex;
  gap: 20px;
}
.tab_group {
  width: 200px;
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 15px;
}

.tab {
  width: 100%;
  height: 107px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #cdcdcd;
  border-radius: 20px;
  font-size: 40px;
  color: white;
  font-weight: bold;
  cursor: pointer;
}

.tab.active {
  background-image: linear-gradient(to right bottom, #ecc07e, #c8974d);
}
.tab_content_group {
  flex-grow: 1;
}
.tab_content {
  width: 100%;
  display: none;
}
.tab_content.active {
  display: block;
}
.tab_banner {
  width: 100%;
  height: 50%;
  margin-bottom: 10px;
}
.tab_banner_img,
.tab_banner_link {
  width: 100%;
  height: 100%;
  max-height: 350px;
  object-fit: cover;
}

.groupA8 .product_wrapper {
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.groupA10 .product_wrapper {
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.product {
  position: relative;
  text-align: center;
}
.product a {
  display: flex;
  gap: 0.4em;
  flex-direction: column;
  transition: all 0.4s;
}

@media (hover: hover) {
  .product a:hover,
  .product a:focus,
  .product a:active {
    transform: translateY(-5px);
  }
}

.prod_img {
  width: 100%;
  padding-bottom: 100%;
  background-size: cover;
  background-position: 50%;
  background-repeat: no-repeat;
  transition: all 0.5s linear;
  background-color: #fff;
  border-radius: 10px;
}

.prod_details {
  display: flex;
  gap: 0.4em;
  flex-direction: column;
}
.prod_desc {
  overflow: hidden;
  padding: 0 5px;
  height: 36px;
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  line-height: 36px;
  background-image: repeating-linear-gradient(90deg, #fa8a67 -1%, #ee5d38 101%);
  width: 90%;
  margin: 0 auto;
  border-radius: 50px;
}
.prod_tit {
  overflow: hidden;
  padding: 4px 5px;
  height: 43px;
  color: #000;
  text-align: center;
  font-size: 16px;
  line-height: 21px;
}
.prod_money {
  padding: 0px 10px 0 10px;
  height: 45px;
  color: #e34357;
  position: relative;
  margin-top: 3px;
}
.prod_money .price {
  margin: 0 2px 0 2px;
  font-weight: 500;
  font-size: 32px;
  line-height: 37px;
}
/**otherbn**/
.otherbn_wrapper {
  background-image: url(../images/bg_otherbn-main.jpg);
}
.otherbn-title{
  max-width: 1200px;
  margin: 0 auto;
  padding: 1em 0 1.6em;
  font-size: 40px;
  font-weight: 500;
  color:#fff;
  text-align: center;
  background-image: url(../images/bg_otherbn-title.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center 0.65em;
}
.otherbn-title span{
  display: inline-block;
}
.otherbn-main {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: auto;
  padding-bottom: 50px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
}
.otherbn-slide {
  width: 50%;
  padding: 10px;
}
.otherbn-slide a {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  padding: 10px;
}
.otherbn-slide a:nth-child(1) {
  border: 4px solid #b8743a;
}
.otherbn-slide a:nth-child(2) {
  border: 4px solid #d83841;
}
.otherbn-slide a:nth-child(3) {
  border: 4px solid #e96240;
}
.otherbn-slide a:nth-child(4) {
  border: 4px solid #792b8e;
}
.otherbn-slide a {
  transition: linear 0.3s;
}
.otherbn-slide a:hover {
  transform: scale(0.98);
  filter: brightness(110%);
}


/**注意事項**/
.notice_wrapper {background: #F26B6B; padding-top: 30px;}
.notice-main {width: 1050px; margin: auto; color: #fff; font-size: 16px; line-height: 18px; padding-bottom: 40px;}
.notice-title {text-align: center; font-size: 24px; font-weight: bold; line-height: 30px; padding-bottom: 10px;}
.notice-main ol li {margin: 0 30px 10px 40px; list-style-type: decimal;}


/**flower**/
#petal_container {
  position: fixed;
  top: 0;
  bottom:0;
  left: 0;
  right: 0;
  margin: auto;
  pointer-events: none;
}
.petal {
  position: absolute;
  width: 10px;
  height: 10px;
  background: url(../images/img_petal.svg) no-repeat;
  animation: fall linear infinite;
  pointer-events: none;
}

@keyframes fall {
  to {
    transform: translateY(100vh) rotate(360deg);
  }
}

@media screen and (min-width: 1025px) {
  /** float **/
  .NavArea {
    display: none;
    width: 140px;
    position: fixed;
    top: 100px;
    right: 0;
    z-index: 999;
    animation: slideLeft 1s ease-in-out 1;
  }
  @keyframes slideLeft {
    0% {
      transform: translateX(150%);
    }
    50% {
      transform: translateX(-8%);
    }
    65% {
      transform: translateX(4%);
    }
    80% {
      transform: translateX(-4%);
    }
    95% {
      transform: translateX(2%);
    }
    100% {
      transform: translateX(0%);
    }
  }
  .Nav {
    display: flex;
    justify-content: center;
  }
  /**active �峕艶highlight**/
  .Nav-slide.active {
    background-color: #153022;
  }
  /**active highlight**/
  .Nav-slide.active a {
    color: #fff;
  }
  .float_tit {
    position: absolute;
    top: -10px;
  }
  .go_top {
    display: block;
    cursor: pointer;
    font-weight: bold;
  }
  .Nav-wrapper {
    width: 115px;
    background: rgb(55 67 86 / 80%);
    border-radius: 15px 15px 4em 4em;
    padding: 110px 5px 10px;
    display: flex;
    flex-direction: column;
    gap: 0.2em;
  }
  .Nav-wrapper li {
    font-size: 15px;
    text-align: center;
    margin: auto;
    position: relative;
    width: 100%;
    border-radius: 20px;
    color: #fff;
  }
  .NavArea .Nav li span {
    display: block;
  }
  li.Nav-title {
    background-color: #7967d5;
    color: #ffe9e9;
    font-weight: bold;
  }
  .Nav-title::before {
    content: "";
    position: absolute;
    left: -10px;
    background: url(../images/icon_Nav-title.png) no-repeat center;
    width: 20px;
    height: 20px;
  }
  .Nav-title::after {
    display: none;
  }
  li.Nav-more {
    background-color: #d55f35;
  }
  /**TOP**/

  .Nav-wrapper li a {
    color: inherit;
    cursor: pointer;
    position: relative;
    z-index: 500;
    font-weight: bold;
    width: 100%;
    border-radius: 20px;
    transition: all 0.2s linear;
    padding: 2px;
    z-index: 1;
  }
  .Nav-wrapper li a:hover {
    color: #ffe9e9;
    background-color: #153022;
  }
  .Nav-wrapper li a:after {
    background: #ffe9e9;
    height: 2px;
    position: absolute;
    right: 51%;
    left: 51%;
    bottom: 0;
    z-index: 2;
    content: "";
    transition-timing-function: ease-out;
    transition-duration: 0.3s;
    transition-property: left, right;
  }
  .Nav-wrapper li a:hover:after {
    right: 10%;
    left: 10%;
  }
}
@media screen and (max-width: 1024px) {
  body {
    min-width: inherit;
  }
  /**M���-float**/
  .NavArea {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    display: none;
  }
  .NavArea .Nav {
    position: relative;
    margin: 0;
    padding: 0;
    overflow-x: scroll;
    background-color: #000;
  }
  .NavArea .Nav ul {
    white-space: nowrap;
  }
  .NavArea .Nav li {
    z-index: 10;
    position: relative;
    display: inline-block;
    padding: 0;
    overflow: hidden;
    width: auto;
    font-weight: inherit;
    text-align: center;
  }

  .NavArea .Nav li span {
    display: inline-block;
  }
  .NavArea .Nav li:nth-child(odd) {
    background-color: #131313;
  }
  .NavArea .Nav a {
    color: #fff;
    text-decoration: none;
    position: relative;
    padding: 0 12px;
    height: 44px;
    line-height: 44px;
  }
  .Nav-slide.active a {
    color: salmon;
  }
  .NavArea .Nav li.Nav-title {
    text-decoration: none;
    position: relative;
    padding: 0 12px;
    height: 44px;
    line-height: 44px;
    color: #fff;
    background-color: #672c34;
  }
  .float_tit {
    display: none;
  }
  .otherbn-slide img {
    width: 100%;
  }
  .NavArea .Nav li.go_top {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  body {
    min-width: 100vw;
    overflow-x: hidden;
  }
  .header {
    width: 100vw;
  }
  .display_m {
    display: block;
  }
  .display_pc {
    display: none;
  }
  .main_wrapper {
    background-size: 240vw !important;
  }
  .kv_wrapper {
    background: none;
  }
  .kv_container {
    width: 100vw;
    height: 58vw;
  }
  .kv_container img {
    width: 100%;
  }
  .kv_logo {
    display: none;
  }
  .kv_slogan {
    width: 60vw;
  }

  /*event_wrapper*/
  .event_wrapper {
    position: relative;
  }
  .event_container {
    height: 31vw;
  }

  .event {
    width: 96vw;
    margin: 0 auto;
  }
  .event .item {
    margin-top: -4vw;
  }
  .event img {
    width: 100%;
  }

  /**prod**/
  .ProductList {
    width: 97vw;
    margin: 0 auto;
  }
  .group {
  }
  .map_item:after,
  .group:before,
  #group_5:after,
  #group_7:after,
  #group_8:before,
  #group_9:after {
    left: -10vw;
    right: -10vw;
    background-size: 100vw;
  }
  .product_wrapper {
  }
  .groupA8 .product_wrapper,
  .groupA10 .product_wrapper {
    grid-template-columns: repeat(2, 1fr);
  }

  .tab_wrapper {
    flex-direction: column;
  }
  .tab_group {
    width: 100%;
    height: 100%;
    gap: 10px;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
  .tab {
    width: 17%;
    min-width: 100px;
    height: 60px;
    font-size: 25px;
  }
  .title_wrapper {
    height: 15vw;
  }
  .title_wrapper .title,.otherbn-title{ 
    font-size: 26px;
  }
  .title_wrapper .more_link {
    font-size: 16px;
  }
  .groupA8 .product,
  .groupTab .product {
  }
  .groupA10 .product {
  }
  .prod_img {
    /* width: 50vw !important; */
    height: 45vw !important;
  }
  .prod_details {
  }
  .prod_desc {
    font-size: 14px;
    width: 95%;
  }
  .prod_tit {
    line-height: 18px;
    font-size: 14px;
    height: 43px;
  }
  .prod_money {
    padding: 0;
    margin-top: 0;
  }
  .prod_money .sign {
    font-size: 14px;
  }
  .prod_money .price {
    font-size: 24px;
  }

  /**floatM-bottom**/
  .float_wrapper {
    display: none;
  }
  .M_menu_wrap {
    position: fixed;
    bottom: 0;
    z-index: 999;
  }
  .M_menu_block {
    width: 100vw;
    background-color: rgb(0 0 0 / 70%);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  .M_menu_block ul {
    border-top: 2px solid #999;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .M_menu_block li {
    width: 100%;
    font-size: 18px;
    line-height: 18px;
    height: 50px;
    display: flex;
    flex: auto;
    justify-content: center;
    align-items: center;
    text-align: center;
    border-left: 1px solid #222;
    border-right: 1px solid #666;
    padding-bottom: 8px;
  }
  .M_menu_block li a {
    color: #fff;
  }
  .M_menu_block a {
    color: #fff;
    display: block;
  }
  .map_item {
    height: 64vw;
    background-size: 80vw;
  }
}
@media screen and (max-width: 576px) {
  .tab {
    width: 25%;
    min-width: 80px;
    height: 35px;
    font-size: 18px;
  }
  .otherbn-title{
    background-image: url(../images/bg_otherbn-title-m.png);
  }
  .otherbn-slide,
  .otherbn-slide a {
    width: 100%;
  }
  .group {
    padding-bottom: 10vw;
  }
  #group_5:after,
  #group_7:after {
    height: 10vw;
  }
  #group_5:before,
  #group_7:before {
    bottom: 10vw;
  }
}
