
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&family=Noto+Serif+TC:wght@200;300;400;500;600;700;900&family=Playfair:ital,wght@1,300&display=swap');
@charset 'utf-8';

/*#Bokeh {
	width: 100%;
	height: 100%;
	position: absolute;
	object-fit: cover;
	top: 0;
	left: 0;
	mix-blend-mode: screen;
	opacity: 1;
}*/
.landing-text {
	position: absolute;
	width: 110%;
	top: 35%;
	right: -25%;
	filter: drop-shadow(0 5px 5px rgba(0,0,0,1)) drop-shadow(0 10px 10px rgba(0,0,0,0.5));
	transform: translateX(100px);
	animation: textEnter 1s ease-in forwards;
	opacity: 0;
}
@media (min-width: 992px) {
	.landing-text {
		position: absolute;
		width: 74%;
		top: 30%;
		right: 0;
		filter: drop-shadow(0 15px 15px rgba(0,0,0,1)) drop-shadow(0 30px 30px rgba(0,0,0,0.5));
		transform: translateX(100px);
		animation: textEnter 1s ease-in forwards;
		opacity: 0;
	}	
}
@keyframes textEnter {
	from {
		transform: translateX(100px);
		opacity: 0;
	} to {
		transform: translateX(0px);
		opacity: 1;
	}
}
.landing-text-1 {
	animation-delay: 1.5s;
}
.landing-text-2 {
	animation-delay: 2s;
}
.landing-text-3 {
	animation-delay: 2.5s;
}
.landing-text-4 {
	animation-delay: 3s;
}
.landing-text [class*="landing-text-"] {
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	transform: translate3d(0,0,0);
}
.landing-text-1-red {
	animation: textRedFadeOut 1s ease-in forwards;
	animation-delay: 4s;
	opacity: 1;
}
.landing-text-2-red {
	animation: textRedFadeOut 1s ease-in forwards;
	animation-delay: 4.5s;
	opacity: 1;
}
.landing-text-3-red {
	animation: textRedFadeOut 1s ease-in forwards;
	animation-delay: 5s;
	opacity: 1;
}
.landing-text-4-red {
	animation: textRedFadeOut 1s ease-in forwards;
	animation-delay: 5.5s;
	opacity: 1;	
}
@keyframes textRedFadeOut {
	from {
		opacity: 1;
		transform: translateX(0%);
		filter: blur(0px);
		-webkit-filter: blur(0px);
	} to {
		opacity: 0;
		transform: translateX(1%);
		filter: blur(30px);
		-webkit-filter: blur(30px);
	}
}


.landing-text-1-overlay {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	mix-blend-mode: screen;
	will-change: transform;
	background: linear-gradient(60deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 48%, rgba(255,247,144,1) 50%, rgba(255,255,255,0) 52%, rgba(255,255,255,0) 100%);
	background-size: 200% 200%;
	background-position: center;
	-webkit-mask-image: url(../images/wave1/landing-text-1-gold.png);
	mask-image: url(../images/wave1/landing-text-1-gold.png);
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	animation: landingTextOverlay 6s ease infinite;
	opacity: 0;
}
.landing-text-2-overlay {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	mix-blend-mode: screen;
	will-change: transform;
	background: linear-gradient(60deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 48%, rgba(255,247,144,1) 50%, rgba(255,255,255,0) 52%, rgba(255,255,255,0) 100%);
	background-size: 200% 200%;
	background-position: center;
	-webkit-mask-image: url(../images/wave1/landing-text-2-gold.png);
	mask-image: url(../images/wave1/landing-text-2-gold.png);
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	animation: landingTextOverlay 6s ease infinite;
	opacity: 0;
}
.landing-text-3-overlay {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	mix-blend-mode: screen;
	will-change: transform;
	background: linear-gradient(60deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 48%, rgba(255,247,144,1) 50%, rgba(255,255,255,0) 52%, rgba(255,255,255,0) 100%);
	background-size: 200% 200%;
	background-position: center;
	-webkit-mask-image: url(../images/wave1/landing-text-3-gold.png);
	mask-image: url(../images/wave1/landing-text-3-gold.png);
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	animation: landingTextOverlay 6s ease infinite;
	opacity: 0;
}
.landing-text-4-overlay {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	mix-blend-mode: screen;
	will-change: transform;
	background: linear-gradient(60deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 48%, rgba(255,247,144,1) 50%, rgba(255,255,255,0) 52%, rgba(255,255,255,0) 100%);
	background-size: 200% 200%;
	background-position: center;
	-webkit-mask-image: url(../images/wave1/landing-text-4-gold.png);
	mask-image: url(../images/wave1/landing-text-4-gold.png);
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	animation: landingTextOverlay 6s ease infinite;
	opacity: 0;
}
.landing-text-1-overlay {
	animation-delay: 7s;
}
.landing-text-2-overlay {
	animation-delay: 7.1s;
}
.landing-text-3-overlay {
	animation-delay: 7.2s;
}
.landing-text-4-overlay {
	animation-delay: 7.3s;
}

@keyframes landingTextOverlay {
	0% {
		background-position: 100% 0%;
		opacity: 0;
	}
	1% {
		opacity: 0.8;
	}
	100% {
		background-position: -100% 0%;
		opacity: 0.8;
	}
}


.landing-doors {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: rgba(0,0,0,1);
	overflow: clip;
	animation: doorsBg 3s ease forwards;
	filter: drop-shadow(0 15px 15px rgba(0,0,0,0));
}
@keyframes doorsBg {
	from {
		background-color: rgba(0,0,0,1);
		filter: drop-shadow(0 15px 15px rgba(0,0,0,0));
	} to {
		background-color: rgba(0,0,0,0);
		filter: drop-shadow(0 15px 15px rgba(0,0,0,1));
	}
}
.landing-door-left {
	/*position: absolute;
	width: 100%;
	top: 0;
	right: 0;
	animation: doorLeftOpen 3s ease forwards;
	animation-delay: 2s;*/
}
.landing-door-left {
	position: absolute;
	width: 50%;
	height: 100%;
	top: 0;
	left: 0;
	background-image: url(../images/wave1/mobile/landing-door-left.png);
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: left;
	animation: doorLeftOpen2 3s ease forwards;
	animation-delay: 1s;
}
@media (min-width: 992px) {
	.landing-door-left {
		position: absolute;
		width: 50%;
		height: 100%;
		top: 0;
		left: 0;
		background-image: url(../images/wave1/landing-door-left.png);
		background-repeat: no-repeat;
		background-size: auto 100%;
		background-position: left;
		animation: doorLeftOpen2 3s ease forwards;
		animation-delay: 1s;
	}	
}
@keyframes doorLeftOpen {
	from {
		transform: translateX(0%);
	} to {
		transform: translateX(-25%);
	}
}

@keyframes doorLeftOpen2 {
	from {
		background-position: left;
	} to {
		background-position: right;
	}
}

.landing-door-right {
	/*display: flex;
	justify-content: flex-end;
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	animation: doorRightOpen 3s ease forwards;
	animation-delay: 2s;*/
}
.landing-door-right {
	position: absolute;
	width: 50%;
	height: 100%;
	top: 0;
	right: 0;
	background-image: url(../images/wave1/mobile/landing-door-right.png);
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: right;
	animation: doorRightOpen2 3s ease forwards;
	animation-delay: 1s;
}
@media (min-width: 992px) {
	.landing-door-right {
		position: absolute;
		width: 50%;
		height: 100%;
		top: 0;
		right: 0;
		background-image: url(../images/wave1/landing-door-right.png);
		background-repeat: no-repeat;
		background-size: auto 100%;
		background-position: right;
		animation: doorRightOpen2 3s ease forwards;
		animation-delay: 1s;
	}
}
@keyframes doorRightOpen {
	from {
		transform: translateX(0%);
	} to {
		transform: translateX(25%);
	}
}
@keyframes doorRightOpen2 {
	from {
		background-position: right;
	} to {
		background-position: left;
	}
}
.left-back-flower-small {
	position: absolute;
	bottom: -2%;
	left: 38%;
	width: 24%;
	animation: leftBackFlowerSmall 30s linear infinite;
}
@media (min-width: 992px) {
	.left-back-flower-small {
		position: absolute;
		top: 21%;
		bottom: initial;
		left: 28%;
		width: 6%;
		animation: leftBackFlowerSmall 30s linear infinite;
	}	
}
@keyframes leftBackFlowerSmall {
	from {
		transform: rotate3d(0,0,1,360deg);
	} to {
		transform: rotate3d(0,0,1,0deg);
	}
}
.left-back-flower {
	position: absolute;
	top: 23%;
	left: -25%;
	width: 58%;
}
@media (min-width: 992px) {
	.left-back-flower {
		position: absolute;
		top: 14%;
		left: 13%;
		width: 28%;
	}	
}
.right-umbrella {
	position: absolute;
	top: -5%;
	left: 55%;
	width: 30%;
	animation: rightUmbrella 30s linear infinite;
}
@media (min-width: 992px) {
	.right-umbrella {
		position: absolute;
		top: -5%;
		left: 55%;
		width: 15%;
		animation: rightUmbrella 30s linear infinite;
	}	
}
@keyframes rightUmbrella {
	from {
		transform: rotate3d(0,0,1,-360deg);
	} to {
		transform: rotate3d(0,0,1,0deg);
	}
}
.golden-snake {
	position: absolute;
	top: -2%;
	left: 52%;
	width: 44%;
	animation: goldenSnake 3s ease-in-out forwards;
	animation-delay: 7s;
	transform-origin: 0% 0%;
	opacity: 0;
}
@media (min-width: 992px) {
	.golden-snake {
		position: absolute;
		top: -2%;
		left: 52%;
		width: 21%;
		animation: goldenSnake 3s ease-in-out forwards;
		animation-delay: 7s;
		transform-origin: 0% 0%;
		opacity: 0;
	}	
}
.golden-snake-inner {
	transform-origin: 0% 0%;
	animation: goldenSnakeInner 10s ease infinite;
}
@keyframes goldenSnakeInner {
	0% {
		transform: rotate(0deg);
	}
	50% {
		transform: rotate(-3deg);
	}
	100% {
		transform: rotate(0deg);
	}
}
@keyframes goldenSnake {
	0% {
		/*transform: rotate3d(0,0,1,-90deg);*/
		opacity: 0;
	} 
	1% {
		/*opacity: 1;*/
	}
	
	100% {
		/*transform: rotate3d(0,0,1,0deg);*/
		opacity: 1;
		filter: drop-shadow(0 30px 10px rgba(0,0,0,0.5));
	}
}

.left-front-flower {
	position: absolute;
	bottom: 0;
	left: -8%;
	width: 29%;
	opacity: 0;
	animation: leftFrontFlower 1s ease forwards;
	animation-delay: 2.8s;
}
@keyframes leftFrontFlower {
	from {
		opacity: 0;
		transform: translateX(-5px);
	} to {
		opacity: 1;
		transform: translateX(0px);
	}
}

.landing-decorations {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	pointer-events: none;
	user-select: none;
	animation: landingDeco 2s ease forwards;
	animation-delay: 3s;
	opacity: 0;
}
@keyframes landingDeco {
	from {
		opacity: 0;
	} to {
		opacity: 1;
	}
}

.tree-left {
	position: absolute;
	top: 0;
	left: -15%;
	width: 50%;
	filter: drop-shadow(0 5px 2px rgba(0,0,0,0.25));
	animation: treeLeft 2s ease forwards;
	animation-delay: 2s;
	opacity: 0;
}
@media (min-width: 992px) {
	.tree-left {
		position: absolute;
		top: 8%;
		left: -5%;
		width: 29%;
		filter: drop-shadow(0 15px 5px rgba(0,0,0,0.25));
		animation: treeLeft 2s ease forwards;
		animation-delay: 2s;
		opacity: 0;
	}	
}
.tree-left-inner {
	animation: treeLeftInner 10s ease infinite;
	transform-origin: 0% 50%;
}
@keyframes treeLeftInner {
	0% {
		transform: rotate3d(0,0,1,-3deg);
	}
	50% {
		transform: rotate3d(0,0,1,3deg);
	}
	100% {
		transform: rotate3d(0,0,1,-3deg);
	}
}
@keyframes treeLeft {
	from {
		transform: translateX(-30px);
		opacity: 0;
	} to {
		transform: translateX(0px);
		opacity: 1;
	}
}
.tree-right {
	position: absolute;
	top: 44%;
	right: -24%;
	width: 46%;
	filter: drop-shadow(0 5px 2px rgba(0,0,0,0.25));
	animation: treeRight 2s ease forwards;
	animation-delay: 2s;
	opacity: 0;
}
@media (min-width: 992px) {
	.tree-right {
		position: absolute;
		top: 32%;
		bottom: initial;
		right: -5%;
		width: 29%;
		filter: drop-shadow(0 15px 5px rgba(0,0,0,0.25));
		animation: treeRight 2s ease forwards;
		animation-delay: 2s;
		opacity: 0;
	}	
}
.tree-right-inner {
	animation: treeRightInner 10s ease infinite;
	transform-origin: 100% 50%;
}
@keyframes treeRightInner {
	0% {
		transform: rotate3d(0,0,1,-3deg);
	}
	50% {
		transform: rotate3d(0,0,1,3deg);
	}
	100% {
		transform: rotate3d(0,0,1,-3deg);
	}
}

@keyframes treeRight {
	from {
		transform: translateX(30px);
		opacity: 0;
	} to {
		transform: translateX(0px);
		opacity: 1;
	}
}
.viva-logo-golden {
	position: absolute;
	top: 22%;
	left: 22%;
	width: 22%;
}
@media (min-width: 992px) {
	.viva-logo-golden {
		position: absolute;
		top: 16%;
		left: 35%;
		width: 8%;
	}	
}

.landing-date {
	position: absolute;
	bottom: 25%;
	left: 24%;
	width: 52%;
	filter: drop-shadow(0 5px 3px rgba(0,0,0,1));
	animation: landingDate 2s ease forwards;
	animation-delay: 6s;
	opacity: 0;
}
@media (min-width: 992px) {
	.landing-date {
		position: absolute;
		bottom: 22%;
		left: 42%;
		width: 16%;
		filter: drop-shadow(0 5px 3px rgba(0,0,0,1));
		animation: landingDate 2s ease forwards;
		animation-delay: 6s;
		opacity: 0;
	}	
}
@keyframes landingDate {
	from {
		opacity: 0;
		transform: translateY(100%);
	} to {
		opacity: 1;
		transform: translateY(0%);
	}
}



















#goldParticles { 
  position: fixed;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: auto;
  width: auto;
  height: 100%;
  z-index: 2;
  /*transform: translateX(-50%) translateY(-50%);*/
  transform: translate3d(0,0,0);
  mix-blend-mode: screen;
  opacity: 1;
  will-change: transform;
  pointer-events: none;
  /*mask-image: linear-gradient(180deg, rgba(0, 0, 0, 1), transparent);*/
  
  /*-webkit-mask-image: linear-gradient(0deg, transparent 33%, rgba(0,0,0,1) 100%);
  mask-image: linear-gradient(0deg, transparent 33%, rgba(0,0,0,1) 100%);
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;*/
}

@media (min-width: 992px) {
	#goldParticles { 
	  opacity: 1;
	  min-height: 100%;
	  height: auto;
	}	
}

#goldStreaks { 
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 90vh;
  width: auto;
  height: auto;
  z-index: 2;
  /*transform: translateX(-50%) translateY(-50%);*/
  transform: translate3d(0,0,0);
  /*mix-blend-mode: normal;*/
  opacity: 1;
  will-change: transform;
}

.sticky-side-menu-1 {
	/*mix-blend-mode: screen;*/
}

.lower-overlay {
	position: absolute;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
	background-image: url(../images/wave1/lower-overlay.png);
	background-size: 100% auto;
	pointer-events: none;
	user-select: none;
}

.gold-particles { 
  position: absolute;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 2;
  /*transform: translateX(-50%) translateY(-50%);*/
  transform: translate3d(0,0,0);
  mix-blend-mode: screen;
  opacity: 1;
  will-change: transform;
}

.gold-particles iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}

#signInTimer {
	display: none;
	background-color: rgba(0,0,0,0.9);
	color: white;
	width: 100%;
	left: 0;
	bottom: 0;
	position: fixed;
	z-index: 99999;
	text-align: center;
	padding: 2rem 1rem;
}
#signInSeconds {
	font-size: 3rem;
	color: yellow;
}
#questComplete {
	display: none;
	font-size: 2rem;
}





.falling-petal {
	position: absolute;
	/*top: 0;
	left: 0;
	right: 0;
	bottom: 0;*/
	z-index: 104;
	pointer-events: none;
	user-select: none;
	width: 100%;
	height: 100svh;
	overflow-x: clip;
	z-index: 3;
}
.dot{
  width: 30px;
  height: 30px;
  position:absolute;
  background: url(../images/wave1/lightstreak.png);
  background-size: 100% 100%;
  pointer-events: none;
	user-select: none;
}

@media (max-width: 992px) {
	.dot {
		width: 16px;
		height: 16px;
	}
}





















.falling-coins {
	display: block;
	position: fixed;
	z-index: 4;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	pointer-events: none;
	user-select: none;
	/*perspective: 500px;*/
	overflow: hidden;
	--coin-size: 40px;
}
@media (min-width: 992px) {
	.falling-coins {
		display: block;
		--coin-size: 100px;
	}
}
.falling-coins > div {
	top: -100px;
	position: absolute;
	pointer-events: none;
	user-select: none;

	/*animation: coinFalling 3s linear infinite;*/
}
@keyframes coinFalling {
	from {
		transform: translateY(0px);
	}
	to {
		transform: translateY(110vh);
	}
}
.falling-coins > div:nth-child(1) {
	left: 5%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: coinFalling 3s linear infinite;
	animation-delay: 0s;
}
.falling-coins > div:nth-child(2) {
	left: 25%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: coinFalling 5.5s linear infinite;
	animation-delay: 3.5s;
}
.falling-coins > div:nth-child(3) {
	left: 40%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: coinFalling 4s linear infinite;
	animation-delay: 2s;
}
.falling-coins > div:nth-child(4) {
	right: 5%;
	width: calc(var(--coin-size) + 0px);
	height: calc(var(--coin-size) + 0px);
	animation: coinFalling 6s linear infinite;
	animation-delay: 0s;
}
.falling-coins > div:nth-child(5) {
	right: 25%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: coinFalling 3.5s linear infinite;
	animation-delay: 3.5s;
}
.falling-coins > div:nth-child(6) {
	right: 40%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: coinFalling 4.5s linear infinite;
	animation-delay: 1.5s;
}
.falling-coins > div > span {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	pointer-events: none;
	user-select: none;
	background-image: url(../images/wave1/coin.png);
	background-size: contain;
	animation: coinRotation 2s linear infinite;
}
.falling-coins > div:nth-child(1) > span {
	animation: coinRotationReverse 1s linear infinite;
}
.falling-coins > div:nth-child(2) > span {
	animation: coinRotation 1.5s linear infinite;
}
.falling-coins > div:nth-child(3) > span {
	animation: coinRotationReverse 2s linear infinite;
}
.falling-coins > div:nth-child(4) > span {
	animation: coinRotation 2s linear infinite;
}
.falling-coins > div:nth-child(5) > span {
	animation: coinRotationReverse 2s linear infinite;
}
.falling-coins > div:nth-child(6) > span {
	animation: coinRotation 1.5s linear infinite;
}

@keyframes coinRotation {
	from {
		transform: rotateX(0deg) rotateY(0deg) rotateZ(-180deg);
		filter: hue-rotate(0deg);
	}
	to {
		transform: rotateX(0deg) rotateY(360deg) rotateZ(180deg);
		filter: hue-rotate(360deg);
	}
}

@keyframes coinRotationReverse {
	from {
		transform: rotateX(0deg) rotateY(0deg) rotateZ(180deg);
		filter: hue-rotate(0deg);
	}
	to {
		transform: rotateX(0deg) rotateY(360deg) rotateZ(-180deg);
		filter: hue-rotate(360deg);
	}
}



.falling-petals {
	display: block;
	position: absolute;
	/*z-index: 104;*/
	width: 100%;
	height: 100vh;
	/*height: 100svh;*/

	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	pointer-events: none;
	user-select: none;
	/*perspective: 500px;*/
	overflow: hidden;
	--coin-size: 16px;
	filter: drop-shadow(0 5px 5px rgba(0,0,0,0.5));
	/*opacity: 0.5;*/
}
.falling-petals-mirror {
	height: 90vh;
	top: 10vh;
	transform: scale(-1,1);
}
@media (min-width: 992px) {
	.falling-petals {
		display: block;
		--coin-size: 150px;
	}
}
.falling-petals > div {
	top: -100px;
	position: absolute;
	pointer-events: none;
	user-select: none;
	opacity: 0;
	animation: coinFalling 3s linear infinite;
}
@keyframes petalsFalling {
	from {
		transform: translateY(0px);
		opacity: 1;
	}

	to {
		transform: translateY(110vh);
		opacity: 1;
	}
}
.falling-petals > div:nth-child(1) {
	left: 10%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 5s linear infinite;
	animation-delay: 0s;
}
.falling-petals > div:nth-child(2) {
	left: 25%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: petalsFalling 7.5s linear infinite;
	animation-delay: 3.5s;
}
.falling-petals > div:nth-child(3) {
	left: 40%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 6s linear infinite;
	animation-delay: 2s;
}
.falling-petals > div:nth-child(4) {
	right: 5%;
	width: calc(var(--coin-size) + 0px);
	height: calc(var(--coin-size) + 0px);
	animation: petalsFalling 8s linear infinite;
	animation-delay: 0s;
}
.falling-petals > div:nth-child(5) {
	right: 20%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: petalsFalling 5.5s linear infinite;
	animation-delay: 3.5s;
}
.falling-petals > div:nth-child(6) {
	right: 35%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 6.5s linear infinite;
	animation-delay: 3.3s;
}
.falling-petals > div:nth-child(7) {
	left: 30%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 5s linear infinite;
	animation-delay: 1.6s;
}
.falling-petals > div:nth-child(8) {
	left: 8%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: petalsFalling 9.5s linear infinite;
	animation-delay: 4.2s;
}
.falling-petals > div:nth-child(9) {
	left: 21%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 6s linear infinite;
	animation-delay: 2.8s;
}
.falling-petals > div:nth-child(10) {
	right: 29%;
	width: calc(var(--coin-size) + 0px);
	height: calc(var(--coin-size) + 0px);
	animation: petalsFalling 8s linear infinite;
	animation-delay: 0.2s;
}
.falling-petals > div:nth-child(11) {
	right: 3%;
	width: calc(var(--coin-size) + 10px);
	height: calc(var(--coin-size) + 10px);
	animation: petalsFalling 10.5s linear infinite;
	animation-delay: 1.5s;
}
.falling-petals > div:nth-child(12) {
	right: 36%;
	width: calc(var(--coin-size) - 10px);
	height: calc(var(--coin-size) - 10px);
	animation: petalsFalling 7.5s linear infinite;
	animation-delay: 3.2s;
}
.falling-petals > div > span {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	pointer-events: none;
	user-select: none;
	background-image: url(../images/wave1/cash-08.png);
	background-repeat: no-repeat;
	background-size: contain;
	animation: petalsRotation 2s linear infinite;
}
.falling-petals > div:nth-child(1) > span {
	animation: petalsRotationReverse 2s linear infinite;
}
.falling-petals > div:nth-child(2) > span {
	animation: petalsRotation 3.5s linear infinite;
}
.falling-petals > div:nth-child(3) > span {
	animation: petalsRotationReverse 4s linear infinite;
}
.falling-petals > div:nth-child(4) > span {
	animation: petalsRotation 2s linear infinite;
}
.falling-petals > div:nth-child(5) > span {
	animation: petalsRotationReverse 2s linear infinite;
}
.falling-petals > div:nth-child(6) > span {
	animation: petalsRotation 1.5s linear infinite;
}

.falling-petals > div:nth-child(7) > span {
	animation: petalsRotationReverse 3s linear infinite;
}
.falling-petals > div:nth-child(8) > span {
	animation: petalsRotation 1.5s linear infinite;
}
.falling-petals > div:nth-child(9) > span {
	animation: petalsRotationReverse 2s linear infinite;
}
.falling-petals > div:nth-child(10) > span {
	animation: petalsRotation 4s linear infinite;
}
.falling-petals > div:nth-child(11) > span {
	animation: petalsRotationReverse 2s linear infinite;
}
.falling-petals > div:nth-child(12) > span {
	animation: petalsRotation 1.5s linear infinite;
}

@keyframes petalsRotation {
	from {
		transform: rotateX(0deg) rotateY(0deg) rotateZ(-180deg);
		filter: hue-rotate(0deg);
	}
	to {
		transform: rotateX(0deg) rotateY(360deg) rotateZ(180deg);
		filter: hue-rotate(0deg);
	}
}

@keyframes petalsRotationReverse {
	from {
		transform: rotateX(0deg) rotateY(0deg) rotateZ(180deg);
		filter: hue-rotate(0deg);
	}
	to {
		transform: rotateX(0deg) rotateY(360deg) rotateZ(-180deg);
		filter: hue-rotate(0deg);
	}
}











#tsparticles {
	
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 50vw;
	/*height: 300px;*/
	transform: translate3d(0,0,0);
	display: block;
	opacity: 1;
	transition: opacity .5s ease;
	background-color: rgba(0,0,0,0);
	z-index: 999;
	pointer-events: none;
	mix-blend-mode: color-dodge;
	z-index: 2;

	will-change: transform;
}


@media (min-width: 992px) {
	#tsparticles {
		
		position: absolute;
		top: 0;
		left: 20%;
		width: 60%;
		height: 70vw;
		/*height: 300px;*/
		transform: translate3d(0,0,0);
		display: block;
		opacity: 1;
		transition: opacity .5s ease;
		background-color: rgba(0,0,0,0);
		z-index: 999;
		pointer-events: none;
		mix-blend-mode: color-dodge;
		z-index: 2;

		will-change: transform;
	}	
}


.tsparticles-wrapper.out-viewport #tsparticles {
	/*display: none;*/
	opacity: 0;
}






.position-relative {
	-webkit-transform: translate3d(0, 0, 0);	/*force hardware acceleration*/	
}


html, body {
	width: 100%;
	font-family: 'Roboto', 'Noto Sans TC', sans-serif;
	image-rendering: -webkit-optimize-contrast;
	image-rendering: optimize-contrast;
	/*max-width: 2560px;*/
	/*background-color: #350306;*/
	/*overflow-x: hidden;*/
	scroll-behavior: smooth;
	scroll-padding-top: 0rem;
	-webkit-font-smoothing: antialiased;	/*force hardware acceleration*/
}
body {
	position: relative;
}

* {
	outline: 0;
	/*outline: 1px solid yellow!important;*/
}

.fs-7 {
	font-size: 0.75rem;
}
body * {
	animation-play-state: paused!important;
}

body.loaded * {
	animation-play-state: running!important;
}
body.loaded.modal-open * {
	animation-play-state: paused;
}
.bg-red {
	background-color: #d63829;
}
.bg-green {
	background-color: #567050;
}
.bg-gold {
	background-color: #a38a4f;
}
.bg-brown {
	background-color: #c22c2b;
}
.loading {
  position: fixed;
  background-color: #c53d0f;
  background-image: url(../images/wave1/loading-bg.jpg);
  /*background-color: transparent;*/
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 10000;
  transition: all 1s ease-out;
  user-select: none;
  pointer-events: none;
}
@media (min-width: 992px) {
	.loading {
	  position: fixed;
	  background-color: #c53d0f;
	  background-image: url(../images/wave1/loading-bg.jpg);
	  /*background-color: transparent;*/
	  display: flex;
	  flex-direction: column;
	  justify-content: center;
	  align-items: center;
	  color: #fff;
	  top: 0;
	  right: 0;
	  bottom: 0;
	  left: 0;
	  z-index: 10000;
	  transition: all 1s ease-out;
	  user-select: none;
	  pointer-events: none;
	}	
}

.loader {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: block;
  border-top: 3px solid #fbe382;
  border-right: 3px solid transparent;
  box-sizing: border-box;
  animation: rotation 1s linear infinite;
  animation-play-state: running!important;
  will-change: transform;
  /*transform: translateZ(0);*/
}
@keyframes rotation {
	from {
		transform: rotate(-360deg);
	}
	to {
		transform: rotate(360deg);
	}
}



a:link,
a:visited,
a:focus,
a:hover,
a:active {
	text-decoration: none;
	color: #fff;
}
a:focus-visible {
	outline: none;
	box-shadow: none;
}

body {
	background-color: #000;
}

body.wave1 {
	background-color: #000;
	background-image: url(../images/wave1/bg-repeat.jpg);
	background-position: top center;
	background-repeat: repeat;
	background-size: 100% auto;
}



.new_glow {
	position: absolute;
	top: 0;
	left: 0;
	mix-blend-mode: screen;
}





.main-section.wave1 {

	position: relative;
	overflow-x: clip;

	background-color: #000616;

	background-image: 
	url(../images/wave1/mobile/bg-upper.png),
	url(../images/wave1/mobile/bg-left.png),
	url(../images/wave1/mobile/bg-right.png),
	url(../images/wave1/mobile/bg-repeat.jpg);

	background-position:
	top center,
	top left,
	top right,
	top center;

	background-repeat: 
	no-repeat,
	repeat-y,
	repeat-y,
	repeat;

	background-size: 
	100% auto,
	100% auto,
	100% auto,
	auto;
}

#navBar {
	/*mix-blend-mode: color-dodge;
	background-color: red;*/
	max-width: 1200px;
	margin: 0 auto 1rem;
}
#navBar .btn-nav {
	/*isolation: isolate;*/
	max-width: 20%;
}




@media (min-width: 992px) {
	#navBar .btn-nav {
		/*isolation: isolate;*/
		max-width: initial;
	}
	#navBar {
		/*mix-blend-mode: color-dodge;
		background-color: red;*/
		margin: 0 auto 3rem;
	}

	#Btn1, #Btn3, #Btn5 {
		transform: translateY(0%);
	}
	#Btn2, #Btn4 {
		transform: translateY(0%);
	}
	
	.main-section.wave1 {
		background-image: 
		url(../images/wave1/bg-upper.png),
		url(../images/wave1/bg-left.png),
		url(../images/wave1/bg-right.png),
		url(../images/wave1/bg-repeat.jpg);

		background-position:
		top center,
		top left,
		top right,
		top center;

		background-repeat: 
		no-repeat,
		repeat-y,
		repeat-y,
		repeat;

		background-size: 
		100% auto,
		100% auto,
		100% auto,
		auto;
	}
	
}



.merry-xmas {
	position: absolute;
	top: 10.5%;
	left: 8.8%;
	width: 10%;
	mix-blend-mode: screen;
	animation: merryXmas 6s infinite;
	animation-timing-function: steps(6, start);
}
@keyframes merryXmas {
	0% {
		filter: hue-rotate(0deg);
	}
	/*50% {
		filter: hue-rotate(30deg);
	}*/
	100% {
		filter: hue-rotate(360deg);
	}
}

.tree-light {
	position: absolute;
	top: 45%;
	left: -6%;
	width: 30%;
	mix-blend-mode: screen;
	
}
@media(min-width: 992px) {
	.tree-light {
		position: absolute;
		top: 34.5%;
		left: 15.8%;
		width: 22.6%;
		mix-blend-mode: screen;
		animation: treeLight 6s infinite;
		animation-timing-function: steps(6, start);
	}	
}

@keyframes treeLight {
	0% {
		filter: hue-rotate(360deg);
	}
	/*50% {
		filter: hue-rotate(30deg);
	}*/
	100% {
		filter: hue-rotate(0deg);
	}
}
.happy-new-year {
	position: absolute;
	top: 5%;
	right: 0%;
	width: 15%;
	/*outline: 1px solid yellow;*/
	background-image: url(../images/wave1/happy-new-year-keyframes.png), url(../images/wave1/happy-new-year-back.png);
	background-size: 2100%, 100%;
	background-position: top left, top left;
	animation: happyNewYear 10.5s steps(21) infinite;
	backdrop-filter: drop-shadow(0 0 5px rgba(0,0,0,0.5));
}
@media (min-width: 992px) {
	.happy-new-year {
		position: absolute;
		top: -10%;
		right: 6%;
		width: 15.625%;
		/*outline: 1px solid yellow;*/
		background-image: url(../images/wave1/happy-new-year-keyframes.png), url(../images/wave1/happy-new-year-back.png);
		background-size: 2100%, 100%;
		background-position: top left, top left;
		animation: happyNewYear 10.5s steps(21) infinite;
		backdrop-filter: drop-shadow(0 0 5px rgba(0,0,0,0.5));
	}	
}
@keyframes happyNewYear {
	from { 
		background-position: 0px;
	}
    to {
    	background-position: -2100%;
    }
}
.xmas-tree {
	position: absolute;
	top: 19%;
	right: -8%;
	width: 27%;
	/*animation: xmasTreeMobile 2s infinite;
	animation-timing-function: steps(2, start);*/
}
@media(min-width: 992px) {
	.xmas-tree {
		position: absolute;
		top: 19%;
		right: 14.5%;
		width: 15.625%;
		animation: xmasTree 6s infinite;
		animation-timing-function: steps(6, start);
	}	
}
@keyframes xmasTreeMobile {
	0% {
		filter: hue-rotate(0deg);
	}
	/*50% {
		filter: hue-rotate(30deg);
	}*/
	100% {
		filter: hue-rotate(60deg);
	}
}
@keyframes xmasTree {
	0% {
		filter: hue-rotate(0deg);
	}
	/*50% {
		filter: hue-rotate(30deg);
	}*/
	100% {
		filter: hue-rotate(360deg);
	}
}
.xmas-tree-star {
	position: absolute;
	top: 19%;
	right: -8%;
	width: 27%;
	/*animation: xmasTreeStar 3s linear infinite;*/
}
@media (min-width: 992px) {
	.xmas-tree-star {
		position: absolute;
		top: 19%;
		right: 14.5%;
		width: 15.625%;
		/*animation: xmasTreeStar 3s linear infinite;*/
	}	
}
@keyframes xmasTreeStar {
	0% {
		filter: drop-shadow(0 0 0px rgba(239,230,142,1)) brightness(90%);
	}
	50% {
		filter: drop-shadow(0 0 120px rgba(239,230,142,1)) brightness(130%);
	}
	100% {
		filter: drop-shadow(0 0 0px rgba(239,230,142,1)) brightness(90%);
	}
}

.landing-bg {
	width: 100%;
	position: relative;
	overflow-x: clip;
}


.wave1 .landing-logo {
	width: 90%;
	top: 16%;
	left: 4%;
	position: absolute;
	/*animation: landingLogo 1s ease-in-out forwards;
	animation-delay: 1s;
	opacity: 0;*/
	/*filter: drop-shadow(0 0 15px rgba(0,0,0,0.5));*/
}
@media (min-width: 992px) {
	.wave1 .landing-logo {
		width: 46.875%;
		top: 24%;
		left: 27%;
		/*filter: drop-shadow(0 0 15px rgba(0,0,0,0.5)) drop-shadow(0 50px 50px rgba(0,0,0,0.25));*/
	}	
}
@keyframes landingLogo {
	0% {
    opacity: 0;
    -webkit-transform: scale(.3);
    -ms-transform: scale(.3);
    transform: scale(.3);
  }

  50% {
    opacity: 1;
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    transform: scale(1.05);
  }

  70% {
  	opacity: 1;
    -webkit-transform: scale(.9);
    -ms-transform: scale(.9);
    transform: scale(.9);
  }

  100% {
  	opacity: 1;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}



.wave1 .landing-logo-text-overlay {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	mix-blend-mode: screen;

	will-change: transform;
	
	background: linear-gradient(60deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 45%, rgba(255,247,144,1) 50%, rgba(255,255,255,0) 55%, rgba(255,255,255,0) 100%);
	background-size: 200% 200%;
	background-position: center;
	-webkit-mask-image: url(../images/wave1/landing-logo-text-overlay.png);
	mask-image: url(../images/wave1/landing-logo-text-overlay.png);
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	animation: landingLogoTextOverlay 6s ease infinite;
	opacity: 1;
}
@keyframes landingLogoTextOverlay {
	from {
		background-position: 100% 0%;
	}
	to {
		background-position: -100% 0%;
	}
}

@keyframes landingPopup {
	0% {
	    transform: scale(0);
	}
	5%, 10% {
		transform: scale(0.9) rotate(-3deg);
	}
	15%, 25%, 35%, 45% {
	    -webkit-transform: scale(1.1) rotate(3deg);
	    -ms-transform: scale(1.1) rotate(3deg);
	    transform: scale(1.1) rotate(3deg);
	}
	20%, 30%, 40% {
	    -webkit-transform: scale(1.1) rotate(-3deg);
	    -ms-transform: scale(1.1) rotate(-3deg);
	    transform: scale(1.1) rotate(-3deg);
	}
	50% {
	    -webkit-transform: scale(1) rotate(0);
	    -ms-transform: scale(1) rotate(0);
	    transform: scale(1) rotate(0);
	}
	100% {
	    -webkit-transform: scale(1) rotate(0);
	    -ms-transform: scale(1) rotate(0);
	    transform: scale(1) rotate(0);
	}
	
}

.wave1 .left-trapeze {
	display: none;
	position: absolute;
	left: 0%;
	top: -12%;
	width: 18%;
	transform-origin: 66% 0%;
	animation: leftTrapeze 5s ease-in-out infinite;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes leftTrapeze {
	0% {
		transform: rotate3d(0,0,1,5deg);
	}
	50% {
		transform: rotate3d(0,0,1,-5deg);
	}
	100% {
		transform: rotate3d(0,0,1,5deg);
	}
}
@media (min-width: 992px) {
	.wave1 .left-trapeze {
		display: block;
		position: absolute;
		left: 14%;
		top: -12%;
		width: 14%;
		transform-origin: 66% 0%;
		animation: leftTrapeze 5s ease-in-out infinite;
	}
	@keyframes leftTrapeze {
		0% {
			transform: rotate3d(0,0,1,5deg);
		}
		50% {
			transform: rotate3d(0,0,1,-5deg);
		}
		100% {
			transform: rotate3d(0,0,1,5deg);
		}
	}	
}

.wave1 .right-trapeze {
	position: absolute;
	right: 0%;
	top: -7%;
	width: 24%;
	transform-origin: 66% 0%;
	animation: rightTrapeze 5s ease-in-out infinite;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes rightTrapeze {
	0% {
		transform: rotate3d(0,0,1,-15deg);
	}
	50% {
		transform: rotate3d(0,0,1,15deg);
	}
	100% {
		transform: rotate3d(0,0,1,-15deg);
	}
}
@media (min-width: 992px) {
	.wave1 .right-trapeze {
		position: absolute;
		right: 8%;
		top: -7%;
		width: 16%;
		transform-origin: 66% 0%;
		animation: rightTrapeze 5s ease-in-out infinite;
	}
	@keyframes rightTrapeze {
		0% {
			transform: rotate3d(0,0,1,-15deg);
		}
		50% {
			transform: rotate3d(0,0,1,15deg);
		}
		100% {
			transform: rotate3d(0,0,1,-15deg);
		}
	}	
}

.wave1 .left-acrobat {
	position: absolute;
	left: -5%;
	top: 25%;
	width: 32%;
	transform-origin: 50% 100%;
	animation: leftAcrobat 6s ease-in-out forwards;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes leftAcrobat {
	0% {
		transform: translate3d(-100%,0,0);
	}
	100% {
		transform: translate3d(0%,0,0);
	}
}
@media (min-width: 992px) {
	.wave1 .left-acrobat {
		position: absolute;
		left: 3%;
		top: 20%;
		width: 16%;
		transform-origin: 50% 100%;
		animation: leftAcrobat 6s ease-in-out forwards;
	}
	@keyframes leftAcrobat {
		0% {
			transform: translate3d(-100%,0,0);
		}
		100% {
			transform: translate3d(0%,0,0);
		}
	}	
}
.wave1 .left-acrobat-inner {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	transform-origin: 50% 100%;
	animation: leftAcrobatInner 2s ease-in-out infinite;
}
.wave1 .left-acrobat-inner:after {
	content: '';
	display: block;
	position: absolute;
	top: 24%;
	left: -10%;
	width: 60%;
	padding-top: 60%;
	background-image: url(../images/wave1/hula-hoop.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	animation: hulaHoop 10s linear infinite;
	transform-origin: 50% 50%;
}
@keyframes hulaHoop {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}



@keyframes leftAcrobatInner {
	0% {
		transform: rotate3d(0,0,1, 0deg);
	}
	50% {
		transform: rotate3d(0,0,1, 3deg);
	}
	100% {
		transform: rotate3d(0,0,1, 0deg);
	}
}
.wave1 .right-acrobat {
	position: absolute;
	right: -5%;
	top: 8%;
	width: 36%;
	transform-origin: 66% 0%;
	animation: rightAcrobat 5s ease-in-out forwards;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes rightAcrobat {
	0% {
		transform: translate3d(100%,0,0);
	}
	100% {
		transform: translate3d(0%,0,0);
	}
}

@media (min-width: 992px) {
	.wave1 .right-acrobat {
		position: absolute;
		right: 2%;
		top: 20%;
		width: 18%;
		transform-origin: 66% 0%;
		animation: rightAcrobat 5s ease-in-out forwards;
	}
	@keyframes rightAcrobat {
		0% {
			transform: translate3d(100%,0,0);
		}
		100% {
			transform: translate3d(0%,0,0);
		}
	}	
}

.wave1 .right-acrobat-inner {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	animation: rightAcrobatInner 2s ease-in-out infinite;
	transform-origin: 50% 50%;
}
@keyframes rightAcrobatInner {
	0% {
		transform: rotate3d(0,0,1, -3deg);
	}
	50% {
		transform: rotate3d(0,0,1, 3deg);
	}
	100% {
		transform: rotate3d(0,0,1, -3deg);
	}
}
.wave1 .right-acrobat-inner:after {
	content: '';
	display: block;
	position: absolute;
	top: -8%;
	left: 34%;
	width: 66%;
	padding-top: 66%;
	background-image: url(../images/wave1/gold-coins.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	animation: goldCoins 2s ease-in-out infinite;
	transform-origin: 50% 50%;
}
@keyframes goldCoins {
	0% {
		transform: rotate3d(0,0,1, 3deg);
	}
	50% {
		transform: rotate3d(0,0,1, -3deg);
	}
	100% {
		transform: rotate3d(0,0,1, 3deg);
	}
}



.wave1 .landing-hat {
	position: absolute;
	top: 60%;
	right: 0%;
	width: 25%;
	animation: landingHat 8s ease-in-out infinite;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes landingHat {
	0% {
		transform: rotate3d(0,0,1, -20deg);
	}
	50% {
		transform: rotate3d(0,0,1, -30deg);
	}
	100% {
		transform: rotate3d(0,0,1, -20deg);
	}
}
@media (min-width: 992px) {
	.wave1 .landing-hat {
		position: absolute;
		top: 51%;
		right: 16%;
		width: 15%;
		animation: landingHat 8s ease-in-out infinite;
	}
	@keyframes landingHat {
		0% {
			transform: rotate3d(0,0,1, -20deg);
		}
		50% {
			transform: rotate3d(0,0,1, -30deg);
		}
		100% {
			transform: rotate3d(0,0,1, -20deg);
		}
	}	
}



.wave1 .small-dove {
	position: absolute;
	top: 27%;
	left: 36%;
	width: 5%;
	animation: smallDove 5s ease-in-out infinite;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes smallDove {
	0% {
		transform: translateY(0) rotate(0deg);
	}
	50% {
		transform: translateY(5px) rotate(0deg);
	}
	100% {
		transform: translateY(0) rotate(0deg);
	}
}
.wave1 .big-dove {
	position: absolute;
	top: 0%;
	left: -4%;
	width: 26%;
	animation: bigDove 5s ease-in-out infinite;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes bigDove {
	0% {
		transform: translateY(0) rotate(0deg);
	}
	50% {
		transform: translateY(15px) rotate(0deg);
	}
	100% {
		transform: translateY(0) rotate(0deg);
	}
}
@media (min-width: 992px) {
	.wave1 .big-dove {
		position: absolute;
		top: 42%;
		left: 15%;
		width: 14%;
		animation: bigDove 5s ease-in-out infinite;
	}
	@keyframes bigDove {
		0% {
			transform: translateY(0) rotate(0deg);
		}
		50% {
			transform: translateY(15px) rotate(0deg);
		}
		100% {
			transform: translateY(0) rotate(0deg);
		}
	}	
}


.wave1 .shopping-bag {
	position: absolute;
	top: 6%;
	left: 8%;
	width: 16%;
	animation: shoppingBag 5s ease-in-out infinite;
	transform-origin: 20% 0%;
	filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
}
@keyframes shoppingBag {
	0% {
		transform: translateY(0) rotate(0deg);
	}
	50% {
		transform: translateY(15px) rotate(15deg);
	}
	100% {
		transform: translateY(0) rotate(0deg);
	}
}
@media (min-width: 992px) {
	.wave1 .shopping-bag {
		position: absolute;
		top: 47%;
		left: 22%;
		width: 9%;
		animation: shoppingBag 5s ease-in-out infinite;
		transform-origin: 20% 0%;
	}
	@keyframes shoppingBag {
		0% {
			transform: translateY(0) rotate(0deg);
		}
		50% {
			transform: translateY(15px) rotate(15deg);
		}
		100% {
			transform: translateY(0) rotate(0deg);
		}
	}	
}

@media (min-width: 992px) {
	.wave1 .landing-balloon {
		position: absolute;
		top: 3%;
		left: 9%;
		width: 4%;
		filter: drop-shadow(0px 10px 10px rgba(0,0,0,0.75));
		animation: landingBalloon 6s ease-in-out infinite;
	}
	@keyframes landingBalloon {
		0% {
			transform: translateY(0);
		}
		50% {
			transform: translateY(10px);
		}
		100% {
			transform: translateY(0);
		}
	}
}






.primary-section-group,
.secondary-banner {
	width: 100%;
	/*overflow: hidden;*/
	
}

[class*="primary-btn-"] {
	/*transform: translateY(0px);*/
	
	/*transition: all .2s ease;*/
	position: relative;
}
[class*="primary-btn-"] picture {
	/*filter: brightness(100%);*/
}

[class*="primary-btn-"]:hover {
	/*transform: translateY(0px);*/
	
	/*transition: all .2s ease;*/
}
[class*="primary-btn-"]:hover picture {
	/*filter: brightness(120%);*/
}




.primary-btn-1 {
	transform: translateY(-15%) scale(1.2);
	transition: all .2s linear;
}
.primary-btn-2 {
	transform: translateY(15%) scale(1.2);
	transition: all .2s linear;
}
.primary-btn-3 {
	transform: translateY(-15%) scale(1.2);
	transition: all .2s linear;
}


@media (min-width: 992px) {
	.primary-btn-1 {
		transform: translateX(12%) translateY(0%);
		transition: all .2s linear;
	}
	.primary-btn-2 {
		transform: translateY(15%);
		transition: all .2s linear;
	}
	.primary-btn-3 {
		transform: translateX(-12%) translateY(0%);
		transition: all .2s linear;
	}

	.primary-btn-4,
	.primary-btn-5,
	.primary-btn-6,
	.primary-btn-7,
	.primary-btn-8 {
		transform: translateY(0%);
		transition: all .2s linear;
	}

	.primary-btn-1:hover {
		transform: translateX(12%) translateY(-3%);
		transition: all .2s linear;
	}
	.primary-btn-2:hover {
		transform: translateY(12%);
		transition: all .2s linear;
	}
	.primary-btn-3:hover {
		transform: translateX(-12%) translateY(-3%);
		transition: all .2s linear;
	}
	.primary-btn-4:hover,
	.primary-btn-5:hover,
	.primary-btn-6:hover,
	.primary-btn-7:hover,
	.primary-btn-8:hover {
		transform: translateY(-3%);
		transition: all .2s linear;
	}
		
}


/*[class*="primary-btn-"] {
	position: relative;
	transition: all .2s ease;
}*/
#ecOnly {
	width: 100%;
	position: relative;
	background-image: url(../images/wave1/mobile/bg-econly.png);
	background-size: 100% auto;
	background-position: top center;
	background-repeat: no-repeat;
	padding: 50% 8% 15% 8%;
	margin-bottom: 3rem;
}
#ecOnly .btn-nav-group {
	column-gap: .5rem;
}
#ecOnly .oneday-timer {
	position: absolute;
  	top: 4.6%;
  	left: 3rem;
  	width: calc(100% - 6rem);
  	transform: scale(0.75);
}
@media (min-width: 992px) {
	#ecOnly {
		width: 100%;
		position: relative;
		background-image: url(../images/wave1/bg-econly.png);
		background-size: contain;
		background-position: top center;
		background-repeat: no-repeat;
		padding: 21% 8% 15% 8%;
	}
	#ecOnly .btn-nav-group {
		column-gap: 3rem;
	}
	#ecOnly .oneday-timer {
		position: absolute;
	    top: 15.3%;
	    left: 50%;
	    width: 28rem;
	    transform: scale(1);
	}
}
@media (min-width: 2500px) {
	
	#ecOnly {
		padding: 16% 8% 13% 8%;
	}
	#ecOnly .oneday-timer {
		position: absolute;
	    top: 15.3%;
	    left: 50%;
	    width: 28rem;
	    transform: scale(1);
	}
}
#ecOnly .btn-nav {
	max-width: 22%;
}
#ecOnly .btn-nav.active img:first-child {
	display: none;
}
#ecOnly .btn-nav.active img:last-child {
	display: block;
}
#ecOnly .btn-nav:hover {
	/*transform: scale(1.1);*/
}


.btn-nav-group .btn-nav img {
	/*transition: all .2s ease;*/
	/*filter: drop-shadow(0 4px 4px rgba(0,0,0,0.5));*/
}
.btn-nav-group .btn-nav {
	transition: all .2s ease;
	/*filter: drop-shadow(0 4px 4px rgba(0,0,0,0.5));*/
}
.btn-nav-group .btn-nav img:first-child {
	display: block;
}
.btn-nav-group .btn-nav img:last-child {
	display: none;
}

.btn-nav-group .btn-nav:hover img:first-child {
	display: none;
}
.btn-nav-group .btn-nav:hover img:last-child {
	display: block;
}

.wave1 .primary-section-group {
	width: 100%;
	/*padding: 1rem;*/
	/*background-image: url(../images/wave1/mobile/primary-btn-group.jpg);*/
	/*background-repeat: no-repeat;
	background-size: 100% 100%;*/
	margin-top: 0;
	margin-bottom: 0;
	/*gap: 1rem;*/
	filter: drop-shadow(0 15px 10px rgba(89,26,4,0.75));
}
#swpPrimaryBtn1 {
	width: 61%;
}
#swpPrimaryBtn2 {
	width: 37%;
}
@media (min-width: 992px) {
	#swpPrimaryBtn1 {
		width: 62%;
	}
	#swpPrimaryBtn2 {
		width: 38%;
	}
}
.wave1 .primary-section-group .row-1 {
	margin-bottom: 6%;
}
.wave1 .primary-section-group .row-2 {
	margin-bottom: 3%;
}
.wave1 .primary-section-group > .d-flex.flex-column,
.wave1 .primary-section-group > .d-flex.flex-column > .d-flex {
	gap: .5rem;
}

.wave1 .primary-btn-6:after {
	content: '';
	display: block;
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	width: 50%;
	padding-top: 50%;
	background-image: url(../images/wave1/primary-btn-6-after.png);
	background-repeat: no-repeat;
	background-size: 100% auto;
	pointer-events: none;
	user-select: none;
	z-index: 9;
}
@media (min-width: 992px) {
	.wave1 .primary-btn-6:after {
		content: '';
		display: block;
		position: absolute;
		top: 0.5rem;
		right: -1.5rem;
		width: 60%;
		padding-top: 50%;
		background-image: url(../images/wave1/primary-btn-6-after.png);
		background-repeat: no-repeat;
		background-size: 100% auto;
		pointer-events: none;
		user-select: none;
		z-index: 9;
	}	
}
.wave1 .primary-btn-7-a:after {
	content: '';
	display: block;
	position: absolute;
	bottom: -1rem;
	right: 1rem;
	width: 25%;
	padding-top: 25%;
	background-image: url(../images/wave1/primary-btn-7-a-after.png);
	background-repeat: no-repeat;
	background-size: 100% auto;
	pointer-events: none;
	user-select: none;
	z-index: 9;
}
@media (min-width: 992px) {
	.wave1 .primary-btn-7-a:after {
		content: '';
		display: block;
		position: absolute;
		bottom: -1.2rem;
		right: 4rem;
		width: 30%;
		padding-top: 23%;
		background-image: url(../images/wave1/primary-btn-7-a-after.png);
		background-repeat: no-repeat;
		background-size: 100% auto;
		pointer-events: none;
		user-select: none;
		z-index: 9;
	}	
}

.col-a,
.col-b,
.col-c,
.col-d {
	width: 50%;
}




@media (min-width: 992px) {
	[class*="primary-btn-"]:hover {
		/*filter: brightness(110%);*/
		/*transition: all .2s ease;*/
	}
	.rices {
		width: 100%;
		height: 100vh;
		position: absolute;
		top: 0;
		left: 0;
	}
	.left-rice {
		width: 5%;
		padding-top: 5%;
		position: absolute;
		top: 5%;
		left: 5%;
		background: black;
	}

	.col-a,
	.col-b,
	.col-c,
	.col-d {
		width: 25%;
	}
	
	.wave1 .primary-section-group {
		width: 100%;
		max-width: 1080px;
		/*overflow: visible;*/
		padding: .5rem;
		/*background-image: url(../images/wave1/primary-btn-group.jpg);
		background-repeat: no-repeat;
		background-size: 100% auto;*/
		margin-top: 0;
		margin-bottom: 0;
		/*gap: 1rem;*/
		filter: drop-shadow(0 15px 10px rgba(89,26,4,0.5));
	}

	.wave1 .primary-section-group > div:nth-child(1) {
		gap: .5rem;
		padding: .5rem;
	}
	.wave1 .primary-section-group > div:nth-child(1) > div {
		gap: .5rem;
	}

	/*.wave1 .primary-section-group > div:nth-child(2) {
		width: 34%;
		padding: .5rem .5rem .5rem 0;
	}*/
	
	

	.btn-nav-group .btn-nav {
		transition: all .2s ease;
		/*filter: drop-shadow(0 9px 3px rgba(0, 0, 0, 0.25));*/
	}
	.btn-nav-group .btn-nav img:first-child {
		display: block;
	}
	.btn-nav-group .btn-nav img:last-child {
		display: none;
	}

	.btn-nav-group .btn-nav:hover img:first-child {
		display: none;
	}
	.btn-nav-group .btn-nav:hover img:last-child {
		display: block;
	}
}

@media (min-width: 992px) {
	
	[class*="primary-btn-"] img {
		
		transition: all .3s ease-in;
		position: relative;
	}
	
}





.tvoneday-section,
.section-wrapper {
	/*filter: drop-shadow(0 5px 5px rgba(77, 7, 7, 0.5));*/
}
@media (min-width: 992px) {

	.tvoneday-section,
	.section-wrapper {
		/*filter: drop-shadow(0 5px 5px rgba(77, 7, 7, 0.5));*/
	}	
}

.tvoneday-timer {
	/*background-image: url(../images/wave2/mobile/tvoneday-body.png);
	background-repeat: repeat-y;
	background-size: 100% auto;*/
	/*margin-top: -.5rem;
	padding-top: 1rem;*/
	display: flex;
	justify-content: center;
}
.tvoneday-body {
	/*background-image: url(../images/wave2/mobile/tvoneday-body.png);
	background-repeat: repeat-y;
	background-size: 100% auto;*/
	margin-top: 0;
}
.tvoneday-body .item {
	order: 3;
}
.tvoneday-body .item[data-item-id="3153072023"] {
	order: 2;
}
.tvoneday-desc {
	width: 50%;
	order: 1;
}

.tvoneday-section {
	background-image: url(../images/wave1/bg-tvoneday.jpg);
	background-size: 100% auto;
	background-repeat: repeat-y;
	background-position: top center;
	padding-top: 1rem;
	/*padding-bottom: .5rem*/
	position: relative;
	border-radius: 1rem;
	filter: drop-shadow(0 5px 5px rgba(0,0,0,0.5));
}

@media (min-width: 992px) {

	#tvOneDay {
		width: 100%;
		max-width: 1200px;
		overflow-x: clip;
		position: relative;
		/*background-image: url(../images/wave2/tvoneday-bg.png);
		background-repeat: no-repeat;
		background-size: 100% auto;
		background-position: top center;*/
	}
	.tvoneday-header {
		position: relative;
	}
	.tvoneday-timer {
		/*margin-bottom: 2rem;*/
	}
	.tvoneday-section {
		background-image: url(../images/wave1/bg-tvoneday.jpg);
		background-size: 100% auto;
		background-repeat: repeat-y;
		background-position: top center;
		padding-top: 2rem;

		max-width: 1200px;
		position: relative;
		border-radius: 1rem;
		filter: drop-shadow(0 5px 5px rgba(0,0,0,0.5));
	}
	.tvoneday-body {
		/*background-image: url(../images/wave2/tvoneday-bg.png);
		background-repeat: repeat-y;
		background-size: 100% auto;
		margin-top: -1.25rem;*/
	}
	.tvoneday-body .row {
		/*padding: 0 10%!important;*/
	}
	.tvoneday-body .item {
		order: 3;
	}
	.tvoneday-body .item[data-item-id="3153072023"] {
		order: 2;
	}
	.tvoneday-desc {
		width: 33%;
		order: 1;
	}
	.tvoneday-footer {
		margin-top: -1.25rem;
	}

}






@media (min-width: 1400px) {
	body {
		/*padding-bottom: 0;*/
	}
	.fs-xl-5 {
		font-size: 1.25rem!important;
	}
}


.sticky-top-nav {
	position: relative;
}
@media (min-width: 1200px) {
	.sticky-top-nav {
		position: sticky;
		top: 0;
	}	
}

@media (min-width: 1200px) {

	@keyframes clockwiseRotate {
		0% {
			transform: rotate(-360deg)
		}
		100% {
			transform: rotate(360deg);
		}
	}
	@keyframes counterClockwiseRotate {
		0% {
			transform: rotate(360deg)
		}
		100% {
			transform: rotate(-360deg);
		}
	}

}



.us-none {
	user-select: none;
}
::selection {
	color: #fff;
	background: #000;
}


#topNav {
	position: relative!important;
	top: initial!important;
	height: 46px;
	/*background-color: transparent!important;*/
	/*display: none!important;*/
}
footer {
	/*display: none!important;*/
}


*.modal-open {
	/*padding-right: 0!important;*/
}

.modal-backdrop {
  /*background-color: transparent!important;*/
  background-color: rgba(0, 0, 0, 0.3)!important;
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  transition: all .2s linear;
}
.modal-backdrop.show {
  opacity: 1;
}
#app {
	width: 100%;
	overflow-x: clip;
	position: relative;
}



.landing-background {
	position: relative;
}

.landing-table {
	position: absolute;
	width: 100%;
	height: auto;
	left: 0;
	bottom: 0;
	pointer-events: none;
	user-select: none;
}
.landing-main {
	width: 100%;
	/*overflow: hidden;*/
	overflow-x: clip;
	transform: translate3d(0,0,0);
}
@media (min-width: 992px) {
	.landing-main {
		width: 100%;
		/*overflow: hidden;*/
		overflow-x: clip;
		transform: translate3d(0,0,0);
	}	
}






.wave1 .primary-section {
	position: relative;
	z-index: 3;
	width: 100%;
	/*max-width: 1320px;*/
	/*margin: 0 auto;*/
	margin-top: -4rem;
	margin-bottom: 2rem;
	/*background-image: url(../images/wave1/mobile/primary-section-bg.png);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center;*/

}



.secondary-section {
	position: relative;
	z-index: 4;
}






@media (min-width: 992px) {
	.wave1 .primary-section {
		margin-top: 9%;
		margin-bottom: 5rem;
		animation: primaryEnter 2s ease forwards;
		animation-delay: 1.5s;
		opacity: 0;
		/*background-image: url(../images/wave1/primary-section-bg.jpg);
		background-size: 100% auto;
		background-repeat: no-repeat;
		background-position:  top center;*/
	}
	@keyframes primaryEnter {
		from {
			transform: translateY(30px);
			opacity: 0;
		} to {
			transform: translateY(0px);
			opacity: 1;
		}
	}
}
@media (min-width: 2500px) {
	.wave1 .primary-section {
		margin-top: 0%;
		/*background-image: url(../images/wave1/primary-section-bg.jpg);
		background-size: 100% auto;
		background-repeat: no-repeat;
		background-position:  top center;*/
	}
}



/*[class*="secondary-section-btn-"] {
	max-width: 50%;
}
@media (min-width: 992px;) {
	[class*="secondary-section-btn-"] {
		max-width: 25%;
	}
}
.secondary-section-btn-detail {
	width: 23%;
}
@media (min-width: 992px) {
	.secondary-section-btn-detail {
		width: 12.714%;
	}	
}*/
.primary-banner,
.secondary-banner {
	position: relative;
}

































[class*="-section-btn-"] {
	position: relative;
	z-index: 2;
}








.section-title {
	position: relative;
	margin-top: 0rem;
	margin-bottom: .5rem;
}
@media (min-width: 992px) {
	.section-title {
		position: relative;
		margin-top: 0rem;
		margin-bottom: 0rem;
		/*filter: drop-shadow(0px 15px 15px rgba(0,0,0,0.5));*/
	}	

}
.section-zongzi-1 {
	width: 6.79%;
	padding-top: 6.79%;
	background-image: url(../images/wave1/section-zongzi-1.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	top: 0;
	left: 5%;
	position: absolute;
	animation: sectionZongzi1 10s linear infinite;
	filter: drop-shadow(0 3px 3px rgba(0,0,0,0.5));
}
@keyframes sectionZongzi1 {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}
.section-zongzi-2 {
	width: 5.07%;
	padding-top: 5.07%;
	background-image: url(../images/wave1/section-zongzi-2.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	top: 31%;
	left: 15%;
	position: absolute;
	animation: sectionZongzi2 10s linear infinite;
	filter: drop-shadow(0 3px 3px rgba(0,0,0,0.5));
}
@keyframes sectionZongzi2 {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(-360deg);
	}
}
.section-zongzi-3 {
	width: 5.58%;
	padding-top: 5.58%;
	background-image: url(../images/wave1/section-zongzi-3.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	top: 15%;
	right: 15%;
	position: absolute;
	animation: sectionZongzi3 10s linear infinite;
	filter: drop-shadow(0 3px 3px rgba(0,0,0,0.5));
}
@keyframes sectionZongzi3 {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}
.section-zongzi-4 {
	width: 7.65%;
	padding-top: 7.65%;
	background-image: url(../images/wave1/section-zongzi-4.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	top: 0;
	right: 5%;
	position: absolute;
	animation: sectionZongzi4 10s linear infinite;
	filter: drop-shadow(0 3px 3px rgba(0,0,0,0.5));
}
@keyframes sectionZongzi4 {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.section-title-boat {
	width: 18.11%;
	padding-top: 10%;
	background-image: url(../images/wave1/section-title-boat.png);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	top: 10%;
	right: 6%;
	position: absolute;
	animation: sectionTitleBoat 10s ease-in-out infinite;
}
@keyframes sectionTitleBoat {
	0% {
		transform: translateX(10%);
	}
	50% {
		transform: translateX(-10%);
	}
	100% {
		transform: translateX(10%);
	}
}






.section-inner > .section-product,
.section-inner > .section-product-group {
	width: 100%;
}

@media (min-width: 992px) {
	.section-inner > .section-product {
		width: 31%;
	}
	.section-inner > .section-product-group {
		width: 52%;
	}
}





.section-inner .row-cols-1 .item-brand,
.section-inner .row-cols-1 .item-name {
	font-size: 1.25rem;
}

.section-wrapper {
	/*z-index: 6;
	background-color: #780a16b5;
	border: 2px solid #f3ba6a;*/
	/*border-radius: 1rem;*/
	/*background-image: url(../images/wave1/section-bg.jpg);
	background-size: 100% 100%;
	background-repeat: no-repeat;*/
}
.section-a,
.section-c,
.section-e {
	background-image: 
	url(../images/wave1/mobile/section-bg-a-header.png),
	url(../images/wave1/mobile/section-bg-a-footer.png);
	background-size: 100% auto;
	background-repeat: no-repeat, no-repeat;
	background-position: top, bottom;
	margin-bottom: 2rem;
	filter: drop-shadow(0 5px 5px rgba(89,26,4,0.85));
}
.section-a:before,
.section-c:before,
.section-e:before {
	content: '';
	display: block;
	background-image: url(../images/wave1/mobile/section-bg-a-body.png);
	background-size: 100% auto;
	background-repeat: repeat-y;
	width: 100%;
	height: 80%;
	top: 10%;
	left: 0;
	position: absolute;
}
.section-e {
	margin-bottom: 1rem;
}
.section-b,
.section-d {
	background-image: 
	url(../images/wave1/mobile/section-bg-b-header.png),
	url(../images/wave1/mobile/section-bg-b-footer.png);
	background-size: 100% auto;
	background-repeat: no-repeat, no-repeat;
	background-position: top, bottom;
	margin-bottom: 1rem;
	filter: drop-shadow(0 5px 5px rgba(89,26,4,0.85));
}
.section-b:before,
.section-d:before {
	content: '';
	display: block;
	background-image: url(../images/wave1/mobile/section-bg-b-body.png);
	background-size: 100% auto;
	background-repeat: repeat-y;
	width: 100%;
	height: 80%;
	top: 10%;
	left: 0;
	position: absolute;
}
.section-d {
	margin-bottom: 2rem;
}
@media (min-width: 992px) {
	.section-a {
		background-image: url(../images/wave1/section-bg-a.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		margin-bottom: 5rem;
	}
	.section-b {
		background-image: url(../images/wave1/section-bg-b.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		margin-bottom: 3rem;
	}
	.section-c {
		background-image: url(../images/wave1/section-bg-c.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		margin-bottom: 5rem;
	}
	.section-d {
		background-image: url(../images/wave1/section-bg-d.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		margin-bottom: 5rem;
	}
	.section-e {
		background-image: url(../images/wave1/section-bg-e.png);
		background-size: 100% 100%;
		background-repeat: no-repeat;
		margin-bottom: 5rem;
	}

	.section-a:before,
	.section-c:before,
	.section-e:before {
		display: none;
	}
	

	.section-b:before,
	.section-d:before,
	.section-f:before {
		display: none;
	}
	
	
}


#sectionA,
#sectionB,
#sectionC,
#sectionD,
#sectionE,
#sectionF {
	display: flex;
	justify-content: center;
	/*max-width: 1200px;*/
	position: relative;
	/*border-radius: 1rem;*/
	/*filter: drop-shadow(0 5px 5px rgba(0,0,0,0.5));*/
	overflow-x: clip;
}

.section-a,
.section-b,
.section-c,
.section-d,
.section-e,
.section-f {
	max-width: 1320px;
}
.section-row {
	/*background-color: #fff4e9;
	border-radius: 1rem;*/
}

.section-bg-item {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}











.swp-banner-section {
	max-width: 1200px;
	position: relative;
	margin-bottom: 1rem;
	filter: drop-shadow(0 8px 8px rgba(0, 0, 0, 0.5));
}


@media (min-width: 992px) {
	.swp-banner-section {
		max-width: 1200px;
		position: relative;
		margin-top: 0;
		margin-bottom: 5rem;
	}	
}
@media (min-width: 2000px) {
	.swp-banner-section {
		max-width: 1200px;
		position: relative;
		margin-top: 0;
		margin-bottom: 5rem;
	}	
}


@media (min-width: 2560px) {
	/*#sectionA,
	#sectionB,
	#sectionC,
	#sectionD,
	#sectionE,
	.swp-banner-section {
		max-width: 1320px;
	}*/
}

.grid-section-header img {
	width: 100%;
	/*max-width: 800px;*/
}

.section-row {
	/*margin-top: -1rem;*/
}









.border-gold {
	border-color: darkgoldenrod;
}



.main {
	user-select: none;
}

button[id^="pills-"] {
	font-family: system-ui, serif;
	font-size: 1rem;
	color: rgba(255,255,255,.85);
	/*padding: 0;*/
	/*text-shadow: 0 0 5px rgba(0,0,0,1);*/
	transition: all .3s linear;
}

/*button[id^="pills-"]:after {
	content: '';
	display: inline-block;
	position: relative;
	width: .1rem;
	height: .1rem;
	background-color: #fff;
	border-radius: 50%;
	margin: .1rem .5rem;
}*/

/*button[id^="pills-"]:last-child:after {
	content: '';
	display: none;	
}*/

@media (min-width: 992px) {
	button[id^="pills-"] {
		font-family: 'Playfair', serif;
		font-size: 2.5rem;
		color: rgba(255,255,255,1);
		/*padding: 0;*/
		
		transition: all .3s linear;
	}

	/*button[id^="pills-"]:after {
		content: '';
		display: inline-block;
		position: relative;
		width: .5rem;
		height: .5rem;
		background-color: #fff;
		border-radius: 50%;
		margin: .5rem 1rem;
	}	*/
}

/*button[id^="pills-"]:hover {
	color: #fff!important;
	color: #2e170f!important;
	filter: drop-shadow(0 0 10px rgba(255,255,255,0.8));
	transition: all .1s linear;
	background-image: url(../images/wave2/nav-dailysale-active.png);
}
button[id^="pills-"].active {
	background-color: transparent!important;
	color: #fdf3a0!important;
	color: #2e170f!important;
	transition: all .1s linear;
	background-image: url(../images/wave2/nav-dailysale-active.png);
}*/

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
	
}
.nav-link.disabled {
	opacity: 0.25;
}






.btn-chevron {
	font-size: 64px;
	text-shadow: 0 0 4px #000;
	transform: translateY(32px);
}









.btn-dark {
	background: #292929;
	color: #fff;
}

.container-item-app {
	/*background-color: #b20c16;
	background-image: url(../images/bg-satin-2.jpg);
	background-position: top center;
	background-size: contain;
	background-repeat: repeat-y;
	filter: brightness(100%) contrast(110%);*/
	width: 100%;
	overflow-x: clip;
	position: relative;
}



#publicGrid {
	width: 100%;
	/*max-width: 1200px;*/
	position: relative;
	/*background-image: url(../images/wave1/bg-bottom.png);
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position: bottom center;*/
	overflow-x: clip;
	-webkit-transform: translate3d(0, 0, 0);
}










/*#publicGrid.wave1 .btn-nav,
#publicGrid.wave2 .btn-nav {
	padding: 2px!important;
}

#publicGrid .btn > img {
	border-radius: .5rem;
}
#publicGrid .btn > img:first-child {
	display: none;
}
#publicGrid bu.btntton > img:last-child {
	display: inline;
}

#publicGrid .btn:hover > img:first-child {
	display: inline;
}

#publicGrid .btn:hover > img:last-child {
	display: none;
}*/
#publicGrid .btn {
	transition: all .2s linear;
}
#publicGrid .btn:hover {
	/*transform: translateY(-5px);*/
}

img[src="/html/images/act/2022/11/11/images/img-error.png"] {
	background-color: #2b0205;
}


#swpGroup {
	top: 53%;
	left: 0;
}
#swpInner {
	width: 51.5625%;
	overflow: hidden;
}
#swpLeft {
	width: 41.287%;
}
#swpRight {
	width: 58.712%;
}


.swiper-custom {
	width: 100%;
	overflow: hidden;
	/*max-width: 1200px;*/
}
.swiper-custom .swiper-slide {
	padding: 0.5rem;

}

@media (max-width: 768px) {
	.swiper-custom .swiper-slide {
		padding: 0rem 0.25rem 1rem;
	}	
}



/*.swiper-custom .swiper-slide img {
	border-radius: 0rem;
	box-shadow: 0 0.5rem 0.75rem rgba(0, 0, 0, 0.25);
	transition: all .2s linear;
	border: 2px solid #f8c574;
}
.wave3 .swiper-custom .swiper-slide img {
	border-radius: 0rem;
	box-shadow: 0 0.5rem 0.75rem rgba(0, 0, 0, 0.25);
	transition: all .2s linear;
	border: 0px solid #f8c574;
}
.swiper-custom .swiper-slide img:hover {
	transform: scale(1.02);
	position: relative;
	z-index: 9999;
}*/

@media (min-width: 992px) {
	/*.swiper-custom .swiper-slide img {
		border: 4px solid #f8c574;
	}
	.wave3 .swiper-custom .swiper-slide img {
		border: 0px solid #f8c574;
	}*/
}

.swiper-custom .swiper-wrapper {
	transition-timing-function: linear;
}

@media (max-width: 991px) {

	#swpGroup {
		top: 53.5%;
		left: 0;
	}
	#swpInner {
		width: 99.5%;
	}
	#swpLeft {
		width: 41.287%;
	}
	#swpRight {
		width: 58.712%;
	}
}





.btn-go-now {
	background-color: #d3d3be;
	color: #555536;
	font-size: 1.25rem;
}

.custom-text {
	color: #a98044;
	/*font-size: 20px;*/
	font-weight: 300;
}
.custom-text li {
	margin-bottom: 1rem;
}

@media (min-width: 1200px) {
	.custom-text {
		color: #a98044;
		font-size: 1.25rem;
		font-weight: 100;
	}
	
}

.event-rule {
	font-size: 1rem;
	color: #70734e;
	font-weight: 300;
}
@media (min-width: 1200px) {
	.event-rule {
		font-size: 1.25rem;
		font-weight: 100;
	}	
}
.countdown {
	/*background-image: url(../images/wave1/bg-countdown.png);*/
	/*background-repeat: no-repeat;
	background-position: center;
	background-size: contain;*/
	color: #ffffff;
	/*background-color: #000;*/
	font-size: 18px;
	/*padding: .125rem .125rem;*/
	
	/*background-color: rgba(255,255,255,.85);*/
	border-radius: .5rem;
	/*border: 1px solid #4e4e4e;*/
	/*border-top: 2px dashed #222;
	border-bottom: 2px dashed #222;*/
	position: relative;
	/*box-shadow: 0 0 8px #ffffff;*/
}

.countdown-number {
	color: #ffffff;
	font-family: 'Century Gothic';
	font-size: 24px;
	font-weight: bold;
	/*background-color: rgba(255,255,255,.95);*/
	/*border: 1px solid #4e4e4e;*/
	padding: .25rem .25rem;
	border-radius: .25rem;
	margin: 0;
	background-image: url(../images/wave1/countdown-number-bg.png);
	background-size: 100% 100%;
	position: relative;
	text-shadow: 
	0 -2px #ffc53d, 
	2px 0 #ffc53d, 
	0 2px #ffc53d, 
	-2px 0 #ffc53d, 
	-2px -2px #ffc53d,
	-2px 2px #ffc53d,
	2px -2px #ffc53d,
	2px 2px #ffc53d;
}
.countdown-number:after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url(../images/wave1/countdown-number-overlay.png);
	background-size: 100% 100%;
	user-select: none;
	pointer-events: none;
}

@media (min-width: 1200px) {
	.countdown {
		/*background-image: url(../images/wave1/bg-countdown.png);*/
		/*background-repeat: no-repeat;
		background-position: center;
		background-size: auto;*/
		color: #ffffff;
		/*background-color: #000;*/
		font-size: 24px;
		/*padding: .25rem .5rem;
		margin-bottom: -2rem;*/
		/*transform: scale(1.2);*/
		/*border-top: 2px dashed #222;
		border-bottom: 2px dashed #222;*/
	}
	.countdown:before {
		/*content: '';
		display: block;
		width: 100%;
		height: 12px;
		position: absolute;
		top: -12px;
		left: 0;
		background-image: url(../images/wave2/countdown-up.png);
		background-repeat: no-repeat;
		background-position: center;
		pointer-events: none;*/
	}
	.countdown:after {
		/*content: '';
		display: block;
		width: 100%;
		height: 22px;
		position: absolute;
		bottom: -22px;
		left: 0;
		background-image: url(../images/wave2/countdown-down.png);
		background-repeat: no-repeat;
		background-position: center;
		pointer-events: none;*/
	}
	.countdown-number {
		color: #ffffff;
		font-family: 'Century Gothic';
		font-size: 48px;
		/*background-color: rgba(205,171,109,.5);*/
		/*border: 1px solid #4e4e4e;*/
		padding: .125rem .5rem;
		/*border-radius: .25rem;*/
		margin: 0 .125rem;
	}	
}



.side-menu-wrapper-left,
.side-menu-wrapper-right {
	display: none;
}





/*.navbar-observer {
	height: 1px;
	top: -1px;
}*/


.btn-nav-group {
	/*position: sticky;
	top: 0px;*/

	position: relative;
	/*padding-top: 1px;*/
	/*background: url(../images/bg-repeat.jpg);*/
	z-index: 5;
	/*overflow: scroll;*/
	width: 100%;
	flex-wrap: nowrap;
	margin-bottom: 2rem;
	filter: drop-shadow(0px 5px 5px rgba(89,26,4,0.75));
	/*background-color: #350306;
	box-shadow: 0 5px 15px #350306;*/
	/*border-top: 3px solid #732a17;
	border-bottom: 3px solid #732a17;*/
}

@media (min-width: 992px) {
	.btn-nav-group {
		position: relative;
		z-index: 99;
		filter: drop-shadow(0px 10px 10px rgba(89,26,4,0.5));
		/*padding-top: 15rem;*/
	}
}


.btn-nav-group.isSticky {
	/*background-color: #c23b5c;*/
	/*backdrop-filter: blur(5px);
	-webkit-backdrop-filter: blur(5px);
	border-bottom: 2px solid #f3ba6a;*/
}
















.btn {
	box-shadow: none!important;
}


.content-wrapper {
	/*background-image: url(../images/bg-repeat-bottom.png);*/
	background-position: bottom 10px center;
	background-repeat: repeat-x;
}

.cf-container {
	position: relative;
	width: 100%;
	padding: 1.5rem;
	background-color: #002842;
	/*left: 80px;
	bottom: 20px;*/
}


.swiper-pagination {
	width: 100%;
	padding: .5rem 0 .5rem;
	position: relative;
}
.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	display: inline-block;
	border-radius: 50%;
	background-color: #fff;
	opacity: 1;
	margin: 0 4px;
	/*border: 1px solid #fff;*/
}
@media (min-width: 992px) {
	.swiper-pagination-bullet {
		width: 16px;
		height: 16px;
		display: inline-block;
		border-radius: 50%;
		background-color: #fff;
		opacity: 1;
		margin: 0 4px;
		/*border: 1px solid #fff;*/
	}
}




.bg-start {
	width: calc(50% - 570px);
	height: 600px;
	position: absolute;
	top: 0;
	left: 0;
	background-image: url(../images/bg-before.jpg);
	background-repeat: no-repeat;
	background-position: 100% 0%;
	display: none;
	user-select: none;
	pointer-events: none;
}

.bg-end {
	width: calc(50% - 570px);
	height: 600px;
	position: absolute;
	top: 0;
	right: 0;
	background-image: url(../images/bg-after.jpg);
	background-repeat: no-repeat;
	background-position: 0% 0%;
	display: none;
	user-select: none;
	pointer-events: none;
}
@media (min-width: 1400px) {
	.bg-start {
		width: calc(50% - 660px);
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		background-image: url(../images/bg-before.jpg);
		background-repeat: no-repeat;
		background-position: 100% 0%;
		display: block;
	}
	
	.bg-end {
		width: calc(50% - 660px);
		height: 100%;
		position: absolute;
		top: 0;
		right: 0;
		background-image: url(../images/bg-after.jpg);
		background-repeat: repeat-x;
		background-position: 0% 0%;
		display: block;
	}
}


.page-wrapper {
	width: 100%;
	margin: 0 auto;
	position: relative;
	/*min-height: calc(100vh - 100px);*/
	z-index: 0;
}


.header-wrapper {
	width: 100%;
	/*max-width: 1200px;*/
	position: relative;
	margin: 0 auto;
}










.oneday-section {
	width: 100%;
	position: relative;
	z-index: 10;
	padding: .5rem;
	/*background-image: url(../images/wave1/mobile/bg-tvoneday.png);
	background-position: top center;
	background-repeat: no-repeat;
	background-size: 100% auto;*/
}






.oneday-section-stage {
	/*max-width: 1320px;*/
	/*padding: 38% 5% 22% 6%;*/
	padding: .5rem;
	position: relative;
	background-image: url(../images/wave1/tvoneday-repeat.png);
	background-size: 100% auto;
	background-repeat: repeat-y;

	border-image: linear-gradient(90deg, rgba(223,169,73,1) 0%, rgba(252,202,104,1) 12%, rgba(255,238,201,1) 29%, rgba(252,202,104,1) 46%, rgba(223,169,73,1) 65%, rgba(255,238,201,1) 83%, rgba(252,202,104,1) 100%) 10/ 4px;
}

@media (min-width: 992px) {
	.oneday-section {
		width: 100%;
		position: relative;
		z-index: 10;
		padding: 0;
		/*background-image: url(../images/wave1/bg-tvoneday.png);
		background-position: top center;
		background-repeat: no-repeat;
		background-size: auto 100%;*/
	}	
	.oneday-section-stage {
		max-width: 1250px;
		padding: 0;
		box-shadow: inset 0 0 50px black;
	}
	.oneday-section-title {
		padding: 4px 4px 0;
	}
	.oneday-section-body {
		padding: 1rem;
		margin-top: -3rem;
	}
}
/*@media (min-width: 1280px) {
	.oneday-section-stage {
		max-width: 1320px;
		padding: 18% 5% 8% 5%;
	}
}
@media (min-width: 1440px) {
	.oneday-section-stage {
		max-width: 1320px;
		padding: 16% 5% 8% 5%;
	}
}
@media (min-width: 1900px) {
	.oneday-section-stage {
		max-width: 1320px;
		padding: 13% 2% 8% 2%;
	}
}*/

.oneday-timer {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
@media (min-width: 992px) {
	.oneday-timer {
		position: absolute;
		top: 1.5%;
		left: 50%;
		width: 100%;
		transform: translateX(-50%);
	}
}



.oneday-section .item-inner {
	
	
	
	padding: .5rem;
	overflow: clip;
}
.oneday-section .item-body {
	border: 0px solid #ffe68c;
	/*filter: drop-shadow(0 0px 0px rgb(251, 212, 0));
	border-radius: 1rem;*/
}
.oneday-section .item-brand,
.oneday-section .item-name,
.oneday-section .item-brand span,
.oneday-section .item-name span {
	color: #fff;
}
.oneday-section .item-brand a:link, 
.oneday-section .item-brand a:visited, 
.oneday-section .item-brand a:focus, 
.oneday-section .item-brand a:hover, 
.oneday-section .item-brand a:active {
	color: #fff;
}
.oneday-section .item-name a:link, 
.oneday-section .item-name a:visited, 
.oneday-section .item-name a:focus, 
.oneday-section .item-name a:hover, 
.oneday-section .item-name a:active {
	color: #fff;
}


.item-inner {
	--border-size: 4px;
	--border-size-m: 2px;

	


	background: #000;
	

	/*filter: drop-shadow(0 0 5px rgba(0,0,0,0.75));*/

	transition: all .2s linear;
	position: relative;
}


@media (min-width: 992px) {
	
	



	.item-inner:hover {
		transform: translateY(-5px);
	}
	.item-inner:hover:after {
		/*height: calc(100% + calc(2*var(--border-size)));*/

	}

}
.item-inner img {
	/*border-radius: 1rem;*/
	aspect-ratio: 1/1;
}




.item-inner a:link,
.item-inner a:visited,
.item-inner a:focus,
.item-inner a:hover,
.item-inner a:active {
	color: #fffed7;
}



.item-body {
	/*box-shadow: 0 10px 10px rgba(255, 255, 255, .5);*/
	/*border: 2px solid #ffe78e;*/
}

.item-body > a.d-block {
	/*border-top-left-radius: .5rem;
	border-top-right-radius: .5rem;
	border: 1px solid rgb(198, 156, 103);*/
	overflow: hidden;
}



.item-name {
	font-size: 0.875rem;
	line-height: 20px;
	/*color: #fbffe9;*/
}
.item-name span,
.item-brand span,
.item-name a,
.item-brand a {
	display: -webkit-box;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	word-break: break-all;
	height: 1.25rem;
	/*color: #fbffe9;*/
}
.oneday-section .item-name span,
.oneday-section .item-name a {
	display: -webkit-box;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	word-break: break-all;
	height: 1.25rem;
	
}

.item-name.double-lines span,
.item-name.double-lines a {
	/*display: -webkit-box;*/
	display: flex;
	justify-content: center;
	align-items: center;
	/*overflow: hidden;*/
	/*text-overflow: ellipsis;*/
	/*-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;*/
	word-break: break-all;
	white-space: pre-wrap;
	height: 2.75rem;
	text-align: center;
	font-size: 0.875rem;
	line-height: 1.25;
}
@media (min-width: 992px) {
	.item-name.double-lines span,
	.item-name.double-lines a {
		
		font-size: 1.1rem;
		
	}
}
.item-brand {
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 20px;
	color: #fffed7;
	/*background-image: url(../images/wave1/item-brand-bg.png);
	background-size: 100% 100%;*/
	padding: 0 1rem;
}
#sectionA .item-brand,
#sectionC .item-brand {
	/*background-color: #a14040;*/
}

#sectionB .item-brand,
#sectionD .item-brand {
	/*background-color: #345a32;*/
}


.item-brand a:link,
.item-brand a:visited,
.item-brand a:focus,
.item-brand a:hover,
.item-brand a:active {
	color: #fffed7;
}

.item-price {
	font-size: 24px;

	/*font-weight: bold;*/
	color: #dc3c14;
	font-family: 'Century Gothic', 'Noto Sans TC', serif;
	letter-spacing: -1px;
}



@media (max-width: 768px) {
	.item-price {
		font-size: 1rem;
	}
}





.item-price.dollar-sign:before {
	color: #f8cf01;
}

.item-price .price-type {
	color: #fff;
	font-size: 1.25rem;
	font-weight: normal;
}
.item-price .dollar-sign {
	color: #f8cf01;
	font-size: 1.25rem;
}

.item-price span {
	color: #f8cf01;
}

.oneday-section .item-price span.coming-soon,
.oneday-section .item-price span.coming-soon span {
	color: #f8cf01;
}


@media (max-width: 768px) {
	.item-price .price-type,
	.item-price .dollar-sign {
	
		font-size: 0.875rem;
	}
}



.coming-soon {
	font-size: 0.875rem;
}

@media (min-width: 992px) {
	.coming-soon {
		font-size: 1.25rem;
	}	
}

.scrollToTop {
	position: fixed;
	width: 40px;
	height: 40px;
	/*background: #3f3c42;*/
	right: 5px;
	bottom: 5px;
	z-index: 999;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	background-color: #3f3c42;
	border: 0px solid #d49655;
	border-radius: 20px;
}
.scrollToTop .fas {
	font-size: 24px;
	color: #fff;
	line-height: 1;
	height: 1em;
}


ol.list-group {
    list-style: decimal inside;
}
ul.list-group {
    list-style: square inside;
}

.list-group-item {
    display: list-item;
}

.bonus {
	background: #946d31;
	color: #fff;
	font-family: 'Century Gothic', 'Noto Sans TC', serif;
	font-size: 14px;
}
.btn-detail {
	position: absolute;
	top: 170px;
	right: 60px;

	top: 28.5%;
	right: 14.49%;
	z-index: 11;
}
@media (max-width: 374px) {
	.btn-detail {
		
		top: 28%;
		right: 12%;
		
	}
}

.btn-detail .btn {
	font-size: 10px;
	padding: 0.25rem 0.5rem;
}
.p-5px {
	padding: 5px;
}
.item {
	z-index: 2;
}
.shadow-custom {
	/*box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);*/
	box-shadow: 0 .5rem .5rem rgba(0,0,0,.25) !important
}
.section-observer {
	height: 1px;
}
.section-bg {

/*	border: 2px solid #fad193;
	background-color: #ff7800;
	position: relative;*/
}

.section-bg:before {
	content: '';
	display: none;
}
.section-top:before {
	content: '';
	display: none;
}
.section-top:after {
	content: '';
	display: none;
}
.section-bottom:before {
	content: '';
	display: none;
}
.section-bottom:after {
	content: '';
	display: none;
}

.section-oneday .section-body {
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(251,247,240,1) 3%, rgba(243,221,184,1) 100%);
}
.section-oneday .item-inner {
	border: 1px solid #fde9c4;
}









@keyframes rotate-cw {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}

@keyframes rotate-ccw {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(-360deg);
	}
}

iframe {
	/*border-radius: 16px;*/
	overflow: hidden;
}


@media (min-width: 768px) {
	iframe {
		/*border-radius: 25px;*/
		overflow: hidden;
	}

	@keyframes rotate-cw {
		0% {
			transform: rotate(0deg);
		}
		100% {
			transform: rotate(360deg);
		}
	}

	@keyframes rotate-ccw {
		0% {
			transform: rotate(0deg);
		}
		100% {
			transform: rotate(-360deg);
		}
	}

	.btn-wrapper {
		position: absolute;
		top: 67.2%;
		left: 3.03%;
		width: 93.852%;
		height: 25.4%;
		background: none;
	}
	
	
	
	.promo-slider {
		position: absolute;		
		height: auto;
		top: 67.2%;
		left: 38.35%;
		width: 23.196%;
		padding: 0;
		background: none;
	}
	.promo-slider img {
		border: 0px solid #79a57d;
	}
	/*.section-oneday .section-body {
		padding-top: 20px;
		margin-top: -80px;
	}*/
}

@media screen and (min-width: 1200px) {
	
	
	html, body {
		font-size: 16px;
	}
	iframe {
		/*border-radius: 25px;*/
		overflow: hidden;
	}

	.btn-wrapper {
		position: absolute;
		top: 808px;
		left: 37px;
		width: 1145px;
		height: 307px;
		background: none;
	}
	

	
	
	/*wave2*/
	
	.w-40 {
		width: 40%;
	}
	.bonus {
		font-size: 20px;
	}
	.item-name {
		font-size: 1rem;
		line-height: 20px;
	}
	.item-brand {
		font-size: 1rem;
		font-weight: 500;
		line-height: 1.125rem;
		padding: .5rem;
	}

	
	.item-price {
		font-size: 30px;
		
	}

	.item-price.dollar-sign:before {
		font-family: 'Noto Sans TC';
		font-weight: 500;
		content: '$';
		/*font-size: 20px;*/
		color: #946d31;
	}

	.section-oneday .item-price.dollar-sign:before {
		content: '限時$';
	}

	.coming-soon {
		font-size: 1.5rem;
		letter-spacing: -1px;
	}
	
	#app {
		min-height: calc(100vh - 108px);
	}
	

	.cf-container {
		width: 100%;
		padding: 70px 0;
		background-color: #002842;
		position: relative;
	}
	/*.cf-container:before {
		content: '';
		display: block;
		width: calc(50vw - 600px);
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		transform: translateX(-100%);
		background-color: #002842;
	}*/
	.btn-detail {
		position: absolute;
		top: 970px;
		left: 46px;
		width: 167px;
		height: 54px;
	}
	.btn-detail .btn {
		font-size: 16px;
		padding: 0.5rem 1rem;
	}
	
	.page-wrapper {
		width: 100%;
		/*min-height: calc(100vh - 120px);*/
		/*max-width: 1200px;*/
	}
	


	.event-1 {
		width: 555px;
		height: 213px;
		position: absolute;
		right: 7.5%;
		top: 19.5%;
		animation-delay: .5s;
	}

	.event-2 {
		width: 472px;
		height: 198px;
		position: absolute;
		right: 12%;
		top: 43%;
		animation-delay: 1s;
	}
	.event-3 {
		width: 662px;
		height: 493px;
		position: absolute;
		left: 1%;
		bottom: -1%;
		animation-delay: 1.5s;
	}
	.scrollToTop {
		
		right: 10px;
		bottom: 10px;
		
	}
	.modal-open .scrollToTop {
		right: 10px;
	}
	
}

.sticky-side-menu {
	position: sticky;
	top: 0;
	width: 100%;
	/*z-index: 10;*/
	/*margin-top: -200px;*/
}

.sticky-side-menu-2 {
	margin-top: 0;
	animation: stickyEnter 2s ease forwards;
	animation-delay: 2s;
	opacity: 0;
}
@keyframes stickyEnter {
	from {
		transform: translateY(30px);
		opacity: 0;
	} to {
		transform: translateY(0px);
		opacity: 1;
	}
}
@media (min-width: 992px) {
	.sticky-side-menu-2 {
		margin-top: -20%;
	}	
}
@media (min-width: 1200px) {
	.sticky-side-menu-2 {
		margin-top: -24%;
	}
}
@media (min-width: 1900px) {
	.sticky-side-menu-2 {
		margin-top: -22%;
	}
}
@media (min-width: 2500px) {
	.sticky-side-menu-2 {
		margin-top: -13%;
	}	
}

@media (min-width: 1900px) {


	.wave1.side-menu-wrapper-left {
		display: flex;
		justify-content: center;
		position: absolute;
		top: 0;
		left: 0;
		width: 379px;
		height: 1665px;
		z-index: 9999;
		transform: scale(1) translateY(0%);
		transform-origin: 0% 0%;
		
		
	}
	
	.side-menu-wrapper-left .side-menu-body {
		display: flex;
		justify-content: center;
		position: absolute;
		width: 100%;
		height: 100%;
		background-image: url(../images/wave1/side-menu-left.png);
		background-position: top 0px left 0px;
		background-repeat: no-repeat;
		filter: drop-shadow(0 15px 15px rgba(89, 26, 4, 0.5));
		z-index: 2;
	}

	.wave1.side-menu-wrapper-left .side-menu-body > div {
		padding-top: 520px;
		width: 250px;
	}
	
	.side-menu-wrapper-left .side-menu-group-1 {
		margin-bottom: 8.5rem;
	}

	.side-menu-wrapper-left .side-menu-group-3 {
		margin-top: .5rem;
	}
	.side-menu-wrapper-left .btn {
		font-size: 1rem;
		color: transparent;
		padding: 1.5rem 0;
		margin-bottom: 0;
		opacity: 0;
	}
	.side-menu-wrapper-left .side-menu-group-2 .btn {
		font-size: 1rem;
		padding: 1.15rem 0;
		margin-bottom: 0;
	}
	.side-menu-wrapper-left .side-menu-group-3 .btn {
		font-size: 1rem;
		padding: 1.15rem 0;
		margin-bottom: 0;
	}
	.side-menu-wrapper-left .btn:active {
		opacity: 0;
	}
	
	



	.wave1.side-menu-wrapper-right {
		display: flex;
		justify-content: center;
		position: absolute;
		top: 0;
		right: 0;
		width: 379px;
		height: 1665px;
		z-index: 9999;
		transform: scale(1) translateY(0%);
		transform-origin: 100% 0%;
		
	}
	
	.side-menu-wrapper-right .side-menu-body {
		display: flex;
		justify-content: center;
		position: absolute;
		width: 100%;
		height: 100%;
		filter: drop-shadow(0 15px 15px rgba(89, 26, 4, 0.5));
		background-image: url(../images/wave1/side-menu-right.png);
		background-position: top 0px left 0px;
		background-repeat: no-repeat;
		z-index: 2;
	}
	.wave1.side-menu-wrapper-right .side-menu-body > div {
		padding-top: 497px;
		width: 250px;
	}
	
	.side-menu-wrapper-right .side-menu-group-1 {
		margin-bottom: 5.2rem;
	}
	.side-menu-wrapper-right .side-menu-group-3 {
		margin-top: 0rem;
	}
	.side-menu-wrapper-right .btn {
		font-size: 1rem;
		color: transparent;
		padding: 1.1rem 0;
		opacity: 0;
	}
	.side-menu-wrapper-right .side-menu-group-2 .btn {
		font-size: 1rem;
		color: transparent;
		padding: 1.125rem 0;
		opacity: 0;
	}
	.side-menu-wrapper-right .side-menu-group-3 .btn {
		font-size: 1rem;
		color: transparent;
		padding: 1.125rem 0;
		opacity: 0;
	}
	.side-menu-wrapper-right .btn:active {
		opacity: 0;
	}
	.wave1.side-menu-wrapper-right:before {
		/*content: '';
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		padding-top: 100%;
		background-image: url(../images/wave1/glass-ball.png);
		animation: glassBall 60s linear infinite;
		z-index: 1;*/
	}
	@keyframes glassBall {
		from {
			transform: rotate(0deg);
		}
		to {
			transform: rotate(360deg);
		}
	}
	.wave1.side-menu-wrapper-right:after {
		/*content: '';
		display: block;
		position: absolute;
		top: -20%;
		left: -40%;
		width: 200%;
		padding-top: 200%;
		background-image: url(../images/wave1/right-fireworks-keyframes.png);
		animation: rightFireworks 3s steps(3) infinite;
		z-index: 0;*/
	}
	@keyframes rightFireworks {
		from { 
			background-position: 0px;
		}
	    to {
	    	background-position: -300%;
	    }
	}
	
	



	





	

	.side-menu-footer {
		background-color: rgba(50, 24, 23, 0.95);
	}
	.side-menu-footer button {
		color: #e4bc8c!important;
	}
}
@media (min-width: 1900px) {
	
	.wave1.side-menu-wrapper-left {
		left: 3%;
		transform: scale(0.5) translateY(0%);
	}
	.wave1.side-menu-wrapper-right {
		right: 3%;
		transform: scale(0.5) translateY(0%);
	}

	
}
@media (min-width: 2000px) {
	
	.wave1.side-menu-wrapper-left {
		left: 5%;
		transform: scale(0.55) translateY(0%);
	}
	.wave1.side-menu-wrapper-right {
		right: 5%;
		transform: scale(0.55) translateY(0%);
	}

	
}
@media (min-width: 2500px) {
	
	.wave1.side-menu-wrapper-left {
		left: 8%;
		transform: scale(0.7) translateY(0%);
	}
	.wave1.side-menu-wrapper-right {
		right: 8%;
		transform: scale(0.7) translateY(0%);
	}

	
}








@media all and (-ms-high-contrast:none)
{
 
 *::-ms-backdrop, body { height: 100%; } /* IE11 */
 *::-ms-backdrop, .d-flex { display: block!important; } /* IE11 */
 *::-ms-backdrop, .item-name {
 	height: 2.5rem;
 	/*overflow: hidden;*/
 	white-space: nowrap;
 	overflow-x: hidden;
 }

}

/*Turn off animate.css on mobile device*/
@media only screen and (max-width : 1200px) {
	.animate__animated {
		/*CSS transitions*/
		-o-transition-property: none !important;
		-moz-transition-property: none !important;
		-ms-transition-property: none !important;
		-webkit-transition-property: none !important;
		transition-property: none !important;
		/*CSS transforms*/
		-o-transform: none !important;
		-moz-transform: none !important;
		-ms-transform: none !important;
		-webkit-transform: none !important;
		transform: none !important;
		/*CSS animations*/
		-webkit-animation: none !important;
		-moz-animation: none !important;
		-o-animation: none !important;
		-ms-animation: none !important;
		animation: none !important;
	}
}



.ec-only-section {
	max-width: 1320px;
	position: relative;
}
@media (min-width: 992px) {
	.ec-only-section {
		/*max-width: 1320px;*/
		/*background-image: url(../images/wave1/bg-econly.png);
		background-size: 100% auto;
		background-position: top center;
		background-repeat: no-repeat;*/
	}	
}
/*.ec-only-button {
	max-width: 950px;
	filter: drop-shadow(0 0 10px rgba(0,0,0,0.75));
	transition: all .2s linear;
}
@media (min-width: 992px) {
	.ec-only-button:hover {
		transform: translateY(-5px);
		filter: drop-shadow(0 10px 10px rgba(0,0,0,0.5));
		transition: all .2s linear;
	}	
}*/


.ec-only-section .swiper-button-prev,
.ec-only-section .swiper-button-next {
	background-color: #472725;
	padding: 3rem;
	border-radius: 50%;
	top: 40%;
}
.ec-only-section .swiper-button-prev {
	left: -6.5rem;
	transition: all .1s linear;
}
.ec-only-section .swiper-button-next {
	right: -6.5rem;
	transition: all .1s linear;
}

.ec-only-section .swiper-button-prev:hover,
.ec-only-section .swiper-button-next:hover {
	filter: drop-shadow(0 5px 5px rgba(0,0,0,0.5));
	transform: translateY(-5px);
	transition: all .1s linear;
}
.ec-only-section .swiper-button-prev:active,
.ec-only-section .swiper-button-next:active {
	filter: drop-shadow(0 5px 5px rgba(0,0,0,0));
	transform: translateY(0px);
	transition: all .1s linear;
}

.ec-only-section .item-body img {
	/*clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);*/
	/*clip-path: path('m 205.47 481.56 l -187 -187 a 63 63 0 0 1 0 -89.06 l 187 -187 a 63 63 0 0 1 89.06 0 l 187 187 a 63 63 0 0 1 0 89.06 l -187 187 a 63 63 0 0 1 -89.06 0 z');*/
	
	/*clip-path: url(#path);*/
	/*clip-path: url(../images/mask.svg);*/
}
.ec-only-section .item-body {
	/*background-image: url(../images/diamond.png);
	background-repeat: no-repeat;
	background-size: contain;*/
	/*filter: drop-shadow(0 0 5px rgba(0,0,0,0.5));*/

}
.ec-only-section .item-body img {
	/*-webkit-mask: url("../images/mask.png") no-repeat center center;
	mask: url("../images/mask.png") no-repeat center center;
	-webkit-mask-size: contain;
	mask-size: contain;*/
	/*border: 2px solid #e2c89b;
	border-radius: 1.3rem;*/
	border-radius: 0;
}

.btn-ec-only-nav {
	color: #fff;
	background-color: #000;
	border: 1px solid #000;
	border-radius: 0;
	width: 25%;
}
.btn-ec-only-nav:hover,
.btn-ec-only-nav.active {
	color: #fffed7;
	background-color: #333;
	border: 1px solid #fffed7;
	border-radius: 0;
}


@media (min-width: 992px) {
	.btn-ec-only-nav {
		width: auto;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
	}
	.btn-ec-only-nav:first-child {
		border-top-left-radius: 5rem;
		border-bottom-left-radius: 5rem;
	}
	.btn-ec-only-nav:last-child {
		border-top-right-radius: 5rem;
		border-bottom-right-radius: 5rem;
	}
	.ec-only-section .item-body img {
		/*-webkit-mask: url("../images/mask.png") no-repeat center center;
		mask: url("../images/mask.png") no-repeat center center;
		-webkit-mask-size: contain;
		mask-size: contain;*/
		/*border: 5px solid #e2c89b;
		border-radius: 1.3rem;*/
	}	
}
.ec-only-section .item-inner {
	background-color: #000;
	border: 2px solid #000;
	/*background-image: url(../images/wave1/item-bg-econly.png);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: top center;*/
	border-radius: 0;
	box-shadow: none;
	padding: 0.5rem;
}
.ec-only-section .item-inner:hover {
	box-shadow: none;
}
.ec-only-section .item-body {
	box-shadow: none;
	/*padding: 2%;*/
	position: relative;
}
.ec-only-section .item-body:after {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 2rem;
	background-image: url(../images/wave2/diamond-shadow.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	bottom: -20px;
	left: 0;
	
}
.ec-only-section .item-footer {
	/*background-color: #752e18;*/
}
.ec-only-section .item-brand {
	/*background-color: #345a32;*/
	color: #fff;
	background-image: url(../images/wave2/item-brand-bg.jpg);
	padding: 0;
}
.ec-only-section .item-brand span,
.ec-only-section .item-brand a {
	color: #fffed7!important;
	/*filter: drop-shadow(0 1px 2px rgba(0,0,0,0.75));*/
}


.ec-only-title {
	filter: drop-shadow(0 5px 5px rgba(0,0,0,1));
}


.ec-only-section .item-name span,
.ec-only-section .item-name a {
	color: #fff!important;
	
	display: -webkit-box;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	word-break: break-all;
	height: 2.5rem;
	
	text-align: center;
	/*filter: drop-shadow(0 1px 2px rgba(0,0,0,0.75));*/
}

.ec-only-section .item-promote .item-body {
	width: 50%;
	flex-shrink: 0;
}
.ec-only-section .item-promote .item-inner {
	padding: 1rem;
	background-image: url(../images/wave1/primary-btn-group.jpg);
	background-size: 100% 100%;
	background-color: transparent;
}
.ec-only-section .price-type {
	/*color: #f8cf01;*/
}

@media (min-width: 992px) {
	.ec-only-section .price-type {
		font-size: 1.5rem;
	}
	.ec-only-section .btn-shop-go {
		font-size: 1.5rem;
		border-radius: 5rem;
		padding-left: 1rem;
		padding-right: 1rem;
	}
	.ec-only-section .item-brand span,
	.ec-only-section .item-name span,
	.ec-only-section .item-brand a,
	.ec-only-section .item-name a {
		font-size: 1.125rem!important;
	}

	.ec-only-section .item-inner {
		padding: 1rem;
	}
	.ec-only-section .item-promote .item-inner {
		padding: 3rem;
		background-image: url(../images/wave1/econly-promote.jpg);
		background-size: 100% 100%;
		background-color: transparent;
	}

	.ec-only-section .item-promote .item-body {
		width: 30%;
		flex-shrink: 0;
	}

	.ec-only-section .item-promote .item-brand {
		line-height: 2.5rem;
	}

	.ec-only-section .item-promote .item-brand span,
	.ec-only-section .item-promote .item-brand a {
		font-size: 2rem!important;
		height: 2.5rem;
	}
	.ec-only-section .item-promote .item-name span,
	.ec-only-section .item-promote .item-name a {
		font-size: 2rem!important;
		height: 6rem;
	}

	.ec-only-section .item-name span,
	.ec-only-section .item-name a {
		display: -webkit-box;
		overflow: hidden;
		text-overflow: ellipsis;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		word-break: break-all;
		height: 3.5rem;
		line-height: 1.5;
		white-space: pre-wrap;

	}

}

.ec-only-section .item-price {
	/*filter: drop-shadow(0 1px 2px rgba(0,0,0,0.75));*/
}
.ec-only-section .item-price,
.ec-only-section .item-price .price-type,
.ec-only-section .item-price .dollar-sign {
	/*background-color: #472725;*/
	/*color: #fdf3a0!important;*/
	
}

.ec-only-section [data-swiper-slide-index="0"],
.ec-only-section [data-swiper-slide-index="2"],
.ec-only-section [data-swiper-slide-index="3"],
.ec-only-section [data-swiper-slide-index="5"],
.ec-only-section [data-swiper-slide-index="6"],
.ec-only-section [data-swiper-slide-index="8"] {
	/*transform: scale(0.85);*/
}

.ec-only-section .swiper-slide {
	transform: scale(1);
	/*transition: all .5s ease-in;*/
}
.ec-only-section .swiper-slide.swiper-slide-next {
	transform: scale(1);
	/*transition: all .5s ease-out;*/
}

@media (min-width: 992px) {
	.ec-only-section .swiper-slide {
		transform: scale(0.8);
		transition: all .5s ease-in;
	}
	.ec-only-section .swiper-slide.swiper-slide-next {
		transform: scale(1);
		transition: all .5s ease-out;
	}	
}



.parallax {
  perspective: 1px;
  width: 100%;
  height: 100%;
  /*height: 100vh;
  height: 100dvh;*/
  position: absolute;
  top: 5%;
  left: 0;
  /*overflow-x: hidden;
  overflow-y: auto;*/
  display: none;
}
@media (min-width: 992px) {
	.parallax {
		display: block;
	}
}
.parallax__layer {
  position: absolute;
  /*top: 0;
  right: 0;
  bottom: 0;
  left: 0;*/
  width: 100%;
  height: 150%;
  /*display: flex;
  flex-direction: column;*/

}
.parallax__layer--base {
  /*transform: translateZ(0);*/
  opacity: .85;
  background-image: url(../images/wave1/parallax-1-text.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
}
.parallax__layer--back {
  /*transform: translateZ(-1px);*/
  opacity: .75;
  background-image: url(../images/wave1/parallax-1-geo.png);
  background-size: 100% auto;
  background-repeat: repeat-y;
}