@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100..900&display=swap");
@font-face {
  font-family: "HunInn";
  src: url(https://cdn.jsdelivr.net/gh/marsnow/open-huninn-font@1.1/font/jf-openhuninn.eot); /* IE9 Compat Modes */
  src: url(https://cdn.jsdelivr.net/gh/marsnow/open-huninn-font@1.1/font/jf-openhuninn.eot?#iefix) format("embedded-opentype"), url(https://cdn.jsdelivr.net/gh/marsnow/open-huninn-font@1.1/font/jf-openhuninn.woff) format("woff"), url(https://cdn.jsdelivr.net/gh/marsnow/open-huninn-font@1.1/font/jf-openhuninn.ttf) format("truetype"), url(https://cdn.jsdelivr.net/gh/marsnow/open-huninn-font@1.1/font/jf-openhuninn.svg#SealmemoryHeader) format("svg"); /* Legacy iOS */
}
.color-mainColor {
  color: #a1704c;
}

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

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

section {
  width: 100vw;
}
@media all and (max-width: 500px) {
  section {
    margin-bottom: 15vw;
  }
}

.titleBox {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 4vw;
}
@media all and (max-width: 500px) {
  .titleBox {
    margin-bottom: 8vw;
  }
}

.d-flex {
  display: flex;
  align-items: center;
  justify-content: center;
}

.d-block {
  display: block;
}

.d-inlineBlock {
  display: inline-block;
}

html.root {
  font-size: 1.4583333333vw;
}

.entry-content .myfont,
.myfont {
  font-size: 1.4583333333vw;
  letter-spacing: 0.08em;
  text-align: center;
  color: #6b5856;
  font-family: "Noto Sans TC", sans-serif;
  line-height: 2;
  font-weight: 600;
}
@media all and (max-width: 500px) {
  .entry-content .myfont,
  .myfont {
    font-size: 4.1666666667vw;
    letter-spacing: 0.05em;
  }
}
.entry-content .myfont div,
.entry-content .myfont p,
.myfont div,
.myfont p {
  font-size: 1.4583333333vw;
  letter-spacing: 0.08em;
  color: #6b5856;
  font-family: "Noto Sans TC", sans-serif;
  line-height: 2;
  font-weight: 600;
  text-align: center;
}
@media all and (max-width: 500px) {
  .entry-content .myfont div,
  .entry-content .myfont p,
  .myfont div,
  .myfont p {
    font-size: 4.1666666667vw;
    letter-spacing: 0.05em;
  }
}

.myTitleDiv {
  font-size: 1.6666666667vw;
  position: relative;
  margin-top: 5vh;
  margin-bottom: 5vh;
  line-height: 1;
}
@media all and (max-width: 500px) {
  .myTitleDiv {
    margin-top: 2.5vh;
    margin-bottom: 2.5vh;
  }
}
.myTitleDiv .border-left-top {
  width: 1.8em;
  height: 1.2em;
  border-left: 2.5px solid #75331f;
  border-top: 2.5px solid #75331f;
  position: absolute;
  left: -1em;
  top: -0.8em;
}
@media all and (max-width: 500px) {
  .myTitleDiv .border-left-top {
    left: -2em;
    border-left: 1.5px solid #75331f;
    border-top: 1.5px solid #75331f;
  }
}
.myTitleDiv .border-right-bottom {
  width: 1.8em;
  height: 1.2em;
  border-right: 2.5px solid #75331f;
  border-bottom: 2.5px solid #75331f;
  position: absolute;
  right: -0.8em;
  bottom: -0.8em;
}
@media all and (max-width: 500px) {
  .myTitleDiv .border-right-bottom {
    border-right: 1.5px solid #75331f;
    border-bottom: 1.5px solid #75331f;
  }
}

.mytitleBefore {
  font-size: inherit;
  content: " ";
  position: absolute;
  background-color: rgba(169, 156, 133, 0.2);
  top: -0.6em;
  bottom: -0.5em;
  left: -1.8em;
  right: -0.6em;
}
@media all and (max-width: 500px) {
  .mytitleBefore {
    top: -1em;
    left: -2em;
    right: -0.4em;
  }
}

.mytitleAfter {
  font-size: inherit;
  content: " ";
  position: absolute;
  background-color: rgba(169, 156, 133, 0.2);
  top: -0.2em;
  bottom: -0.9em;
  left: -0.5em;
  right: -1.8em;
}
@media all and (max-width: 500px) {
  .mytitleAfter {
    top: -0.4em;
    bottom: -0.9em;
    left: -0.5em;
    right: -1.8em;
  }
}

.entry-content .mytitle,
.mytitle {
  font-family: "HunInn", sans-serif;
  font-size: 1.6666666667vw;
  color: #75331f;
  position: relative;
  margin: 0px;
  line-height: 1;
  letter-spacing: 0px;
}
@media all and (max-width: 500px) {
  .entry-content .mytitle,
  .mytitle {
    font-size: 4.6875vw;
  }
}

.button {
  background-color: #a1704c;
  border-radius: 4em;
  border: 2px solid #a1704c;
  transition: 0.5s;
}
.button a.myfont,
.button a {
  padding: 1em 2.5em;
  color: #fff;
}

.button:hover {
  background-color: #a1704c;
  background-color: #fff;
  border: 2px solid #a1704c;
}
.button:hover a.myfont,
.button:hover a {
  color: #a1704c;
}

.bannerBox {
  position: relative;
  padding-top: 15vh;
  height: 55vh;
}
.bannerBox .bannerText {
  font-family: "Cormorant Garamond", serif;
  font-size: 5.7291666667vw;
  letter-spacing: 0.06em;
  color: #aa9d86;
  opacity: 0.3;
  font-weight: 600;
  white-space: nowrap;
  max-width: 100vw;
  overflow: hidden;
}
.bannerBox .bannerAnimationBox {
  z-index: 20;
  height: 1vh;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.bannerBox .bannerAnimationBox::before, .bannerBox .bannerAnimationBox::after {
  content: " ";
  position: absolute;
  top: 50%;
  left: 0%;
  right: 45%;
  height: 2px;
  background-color: #aa9d86;
  opacity: 0.3;
}
.bannerBox .bannerAnimationBox::after {
  left: 90%;
  right: 0%;
}
.bannerBox .bannerAnimationBox .animationBox {
  width: 35%;
  position: relative;
  left: 55%;
}
.bannerBox .bannerAnimationBox .animationBox .mainVisual {
  width: 100%;
}
@media all and (max-width: 500px) {
  .bannerBox {
    padding-top: 1%;
    height: auto;
    margin-bottom: 0px;
  }
  .bannerBox .bannerText {
    text-align: center;
    font-size: 14.3229166667vw;
    margin-bottom: 5vh;
  }
  .bannerBox .bannerAnimationBox {
    height: 20vh;
  }
  .bannerBox .bannerAnimationBox #main-visual {
    width: 80%;
    left: 10%;
  }
  .bannerBox .bannerAnimationBox::before, .bannerBox .bannerAnimationBox::after {
    left: 0%;
    right: 90%;
  }
  .bannerBox .bannerAnimationBox::after {
    left: 90%;
    right: 0%;
  }
}

body {
  overflow-x: hidden;
}

.main {
  min-height: 100vh;
}

main {
  position: relative;
  z-index: 5;
}

.textCenter {
  text-align: center;
}

/* 動畫區 */
.bannerBox .bannerText {
  opacity: 0;
  transform: translateX(2vw);
  animation: bannerTextAnimation 2s 1s forwards;
}

@keyframes bannerTextAnimation {
  0% {
    transform: translateX(2vw);
    letter-spacing: 0.2em;
    opacity: 0;
  }
  100% {
    transform: translateY(0px);
    opacity: 0.3;
  }
}
.bannerBox .bannerAnimationBox::before {
  opacity: 0;
  animation: bannerAnimationBoxAnimationLeftLine 2s forwards;
}

@keyframes bannerAnimationBoxAnimationLeftLine {
  0% {
    opacity: 0;
    right: 100%;
  }
  100% {
    opacity: 1;
  }
}
.bannerBox .bannerAnimationBox::after {
  opacity: 0;
  animation: bannerAnimationBoxAnimationRightLine 2s forwards;
}

@keyframes bannerAnimationBoxAnimationRightLine {
  0% {
    opacity: 0;
    left: 100%;
  }
  100% {
    opacity: 1;
  }
}
.fadeIn {
  opacity: 0;
  animation: fadeIn 1.5s forwards ease-in;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fadeInDown {
  opacity: 0;
  transform: translateY(-2em);
  animation: fadeInDown 1.5s forwards ease-in;
}

@keyframes fadeInDown {
  0% {
    opacity: 0;
    transform: translateY(-2em);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.fadeInRight {
  opacity: 0;
  transform: translateX(50px);
  animation: fadeInRight 1.5s forwards ease-in;
}

@keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translateX(50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInLeft {
  opacity: 0;
  transform: translateX(-50px);
  animation: fadeInLeft 1.5s forwards ease-in;
}

@keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(-50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInUp {
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInUp 1.5s forwards ease-in-out;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.slideZoomSmall {
  animation: slideZoomSmall 20s alternate linear infinite;
}

@keyframes slideZoomSmall {
  0% {
    transform: scale(1.5);
  }
  100% {
    transform: scale(1);
  }
}
.slideZoomBig {
  animation: slideZoomBig 30s alternate linear infinite;
}

@keyframes slideZoomBig {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.5);
  }
}
.zoomSmall {
  animation: zoomSmall 20s alternate linear infinite;
}

@keyframes zoomSmall {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.2);
  }
}
.zoomBig {
  animation: zoomBig 20s alternate linear infinite;
  transform: scale(1.2);
}

@keyframes zoomBig {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
.blurIn {
  opacity: 0;
  animation: blurIn 1s 0.5s forwards;
}

@keyframes blurIn {
  0% {
    filter: blur(20px);
    opacity: 0;
  }
  100% {
    filter: blur(0px);
    opacity: 1;
  }
}
.title {
  animation: titleAnimation 1.5s forwards;
}

@keyframes titleAnimation {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.DecorationEnfont {
  opacity: 0;
  animation: DecorationEnfontAnimation 1s 0.5s forwards;
}

@keyframes DecorationEnfontAnimation {
  0% {
    transform: scaleX(2);
    transform: scaleY(0.5);
    filter: blur(20px);
    opacity: 0;
  }
  80% {
    filter: blur(0px);
    opacity: 1;
  }
  100% {
    transform: scaleX(1);
    transform: scaleY(1);
    opacity: 1;
  }
}
.ActivityCard {
  opacity: 0;
  animation: ActivityCardAnimation 1s 0.5s forwards;
}

.ActivityCard:nth-of-type(odd) {
  opacity: 0;
  animation: ActivityCardAnimationInOdd 1s 0.5s forwards;
}

@keyframes ActivityCardAnimation {
  0% {
    opacity: 0;
    transform: translateY(3vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@keyframes ActivityCardAnimationInOdd {
  0% {
    opacity: 0;
    transform: translateY(-3vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.titleCircleDiv {
  width: 13.0208333333vw;
  height: 13.0208333333vw;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 30;
  position: absolute;
  top: 40vh;
  left: 8vw;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
@media all and (max-width: 500px) {
  .titleCircleDiv {
    width: 25vw;
    height: 25vw;
    top: 22vh;
  }
}
.titleCircleDiv .popOnDiv {
  width: 95%;
  height: 95%;
}
.titleCircleDiv .titleCircle {
  width: 95%;
  height: 95%;
  position: relative;
  z-index: 5;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  animation: logoShake 0.75s 0.5s forwards ease-out;
  box-shadow: 0px 0px 10px 3px rgb(103, 103, 103);
}
.titleCircleDiv .titleCircle .title {
  font-family: "HunInn", sans-serif;
  font-size: 2.0833333333vw;
  color: #a0704c;
  position: relative;
  margin: 0px;
}
@media all and (max-width: 500px) {
  .titleCircleDiv .titleCircle .title {
    font-size: 4.1666666667vw;
  }
}

/* 自定义动画效果 */
.swiper-slide {
  position: relative;
}

.swiper-slide span {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 100px;
  color: #b64141;
  z-index: 99;
}

@keyframes slideMoveOutAnimation {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.5);
  }
  100% {
    transform: scale(0);
  }
}
@keyframes slideMoveInAnimation {
  0% {
    transform: scaleX(0.5) scaleY(0.5);
  }
  100% {
    transform: scaleX(1) scaleY(1);
  }
}
.site-header {
  border-radius: 3.2vw;
  overflow: visible;
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.5333333333);
}

.text-left,
.text-left p,
.entry-content .text-left,
.entry-content .text-left p {
  text-align: left !important;
}

.color-white,
.color-white p,
.myfont.color-white p,
.entry-content .color-white,
.entry-content .color-white p,
.entry-content .myfont.color-white p {
  color: #ffffff !important;
}

.ast-theme-transparent-header #ast-desktop-header > .ast-main-header-wrap > .main-header-bar {
  border-radius: 10em !important;
}
@media all and (max-width: 500px) {
  .ast-theme-transparent-header #ast-desktop-header > .ast-main-header-wrap > .main-header-bar {
    border-radius: 0em !important;
  }
}

.main-header-bar,
.ast-hfb-header .site-header,
.ast-main-header-wrap {
  border-radius: 20em !important;
}
@media all and (max-width: 500px) {
  .main-header-bar,
  .ast-hfb-header .site-header,
  .ast-main-header-wrap {
    border-radius: 0em !important;
  }
}

.ast-hfb-header .site-header {
  margin-top: 1%;
}

.ast-header-break-point #ast-mobile-header {
  top: 0px;
  left: 0px;
  width: 100vw;
  position: fixed;
}

@media all and (max-width: 500px) {
  .main-navigation .menu-item .menu-link {
    border-bottom-width: 0px !important;
    text-align: center;
  }
}

.delay-point5 {
  animation-delay: 0.5s !important;
}

.delay-point1 {
  animation-delay: 1s !important;
}

.trp-language-switcher-container a {
  font-size: 80%;
  margin-left: 1vw;
}/*# sourceMappingURL=config.css.map */