a {
  text-decoration: none !important;
}
a:hover {
  text-decoration: none !important;
}



.justify-c{
  justify-content: center;
}

.boxTopMar{
  margin-top: 140px!important;
}

.section-title-small{
  margin-bottom: 20px;
}

.cjbflexitem{
  margin: 0px auto!important;
}

p {
  font-size: 16px;
}

.section-title-small{
  font-size: 36px;
}

.PConly {
  display: block;
}
.Mobonly {
  display: none !important;
}

.mb-20.mb-xs-2 {
  margin-bottom: 5px !important;
}

.bg-muji {
  background-color: #7f0019;
}
.muji_color {
  color: #7f0019;
}


#activity-3 h3 {
  font-size: 34px;
}

#activity-3 h3 span {
  font-size: 40px;
}

#services .section-title {
  font-size: 40px;
  letter-spacing: 1px;
  margin-bottom: 2rem;
  font-weight: 900;
}

#services .services-title {
  font-weight: 900;
}

.sf-heading.-h3 {
  font-size: 24px;
  font-weight: 900;
}

#globalHeader .headerWrap {
  width: 90%;
  margin: 0 auto;
  position: relative;
  max-width: 1024px;
}

.page-section .categoryBox {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0 0px;
  gap: 20px;
  flex-wrap: wrap;
}

.categoryList {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  background-color: #f9f9f9;
  padding-right: -calc(var(--bs-gutter-x) * 0.5) !important;
  padding-left: -calc(var(--bs-gutter-x) * 0.5) !important;
  width: 23%;

  position: relative;
  overflow: hidden;
  isolation: isolate;
  transform: translateZ(0);
}

.categoryList a {
  display: contents;
  -webkit-transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
  transition: all 0.2s cubic-bezier(0.3, 0.1, 0.58, 1);
}
.categoryList .categoryL {
  display: flex;
  align-items: center;
  width: 30%;
}
.categoryList .categoryL img {
  width: 100%;
  transform: translateZ(0.1px);
  transition: all 0.5s var(--ease-out-short);
}

.categoryList a:hover .categoryL img {
  transform: scale(1.05) translateZ(0.1px);
}

.categoryList .categoryR {
  font-size: 1rem;
  font-weight: bold;
  width: 65%;
}
.categoryList .categoryR span {
  display: block;
}

@keyframes bounceDown {
  0%,
  20%,
  50%,
  80%,
  100% {
    transform: translateY(0);
  }
  40%,
  60% {
    transform: translateY(10px);
  }
}

/* .menu a:hover .mi-chevron-down */
.saleBox:hover .mi-chevron-down {
  animation: bounceDown 1s infinite;
}
.saleBox i {
  font-size: 25px;
}

.menu {
  position: relative;
  top: 0;
  width: 100%;
  background-color: white;
  z-index: 1000;
  transition: all 0.3s ease;
  display: none;
  z-index: 99999;
}

.menu a {
  padding: 0.5rem 0rem;
  line-height: 0.5;
  font-weight: 700;
  font-size: 18px;
}

.menu a i {
  font-size: 22px;
}

.menu li.active {
  border-bottom: 2px solid #1D1D1F;
}

.menu li.active a{
 color: #7F0019;
}

.menu.fixed {
  position: fixed;
  left: 0;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  display: block;
}

.menu ul {
  display: flex;
  margin: 0px;
  padding: 0rem 0.5rem 0px 0.5rem;
  justify-content: space-around;
  align-items: center;
}

.menu ul li {
  text-align: center;
  position: relative;
  width: 33%;
  padding: 8px 0;
  border: 1px solid transparent;
}

.menu li:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 0;
  right: -5px;
  height: 90%;
  width: 1px;
  background-color: #eee;
}

.oneBox {
  position: relative;
  display: inline-block;
}
.oneBox .candle {
  position: absolute;
  top: -35%;
  left: 25%;
  width: 40px;
}

.oneBox .oneIcon {
  width: 50px;
  display: inline-block;
  vertical-align: bottom;
  margin: 0px 14px 0px 10px;
}

#about .section-title-small {
  font-weight: 900;
  color: #3c3c43;
  letter-spacing: 1px;
  font-size: 32px;
}

.saleCoupon{
  justify-content: center;
  border-bottom: 1px #ddd solid;
}

#about .saleBox{
  width: 250px;
}

#about .saleBox {
  border-bottom: solid 3px transparent;
}

#about .saleBox:hover,#about .saleBox:first-child {
  border-bottom: solid 3px #1D1D1F;
}



#about .saleBox.active:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background-color: #1d1d1f
}

#about .saleBox:not(:first-child):before {
  content: "";
  position: absolute;
  left: -1px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 45px;
  background-color: #d8d8d9
}




img.ribbons {
  position: absolute;
  top: 0;
  left: 0;
}

.activity-accordion .toggle {
  border-bottom: none;
}
.activity-accordion .toggle > dt > a {
  padding: 20px 20px 50px 20px;
  border-top: none;
}



.title-week{
  font-size: 32px;
  font-weight: 900;
  padding: 5px 10px;
  border-radius: 5px;
}

.title-sale{
  font-size: 28px;
  font-weight: 900;
  padding: 5px 10px;
  border-radius: 5px;
}

.passport-flex {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 20px auto 40px auto;
  /* width: 85%; */
  /* max-width: 900px; */
  width: 85%;
}

.passport-flex .passport-item-l {
  width: 40%;
}

.passport-flex .passport-item-r {
  width: 60%;
}

.passport-card {
  display: flex;
  align-items: stretch;
  border-radius: 7px;
  overflow: hidden;
  position: relative;
}

.card-left {
  background: #9d2239;
  color: white;
  width: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 36px;
  font-weight: bold;
  padding: 10px;
}

.card-right {
  background: #efefef;
  display: flex;
  align-items: center;
  flex-grow: 1;
  padding: 10px 15px;
}

img.arrow-down {
  position: absolute;
  left: 156px;
  top: 108px;
  width: 20px;
  z-index: 9999;
}

.card-right .icon {
  width: 140px;
  height: auto;
  margin-right: 10px;
}

.card-right .text {
  font-size: 20px;
  color: #333;
  font-weight: 800;
}

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

.celebrate-box .title-week {
  font-size: 32px;
  font-weight: 900;
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
}

.celebrate-box .title-week::before,
.celebrate-box .title-week::after {
  content: "";
  width: 45px;
  height: 3px;
  background-color: black;
  display: inline-block;
}

.celebrate-box .title-week::before {
  transform: rotate(50deg);
}

.celebrate-box .title-week::after {
  transform: rotate(-50deg);
}

.couponBox .weekserve-container {
  /* max-width: 900px; */
  width: 85%;
  margin: 20px auto;
  padding: 50px 16px;
  background: #fff;
  text-align: center;
}

.couponBox .weekserve-container h4 {
  font-size: 24px;
  font-weight: 800;
  text-align: center;
  margin-bottom: 48px;
}

.couponBox .weekserve-container .grid-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 20px;
}

.join-week .couponBox .weekserve-container .grid-item {
  background: #fff;
  /* padding: 30px; */
  text-align: center;
  border-radius: 10px;
  padding: 38px 40px;
}

.couponBox .weekserve-container h3 {
  font-size: 24px;
  font-weight: 800;
  margin-top: 15px;
  margin-bottom: 10px;
}

.join-week .couponBox .weekserve-container p {
  font-size: 15px;
  color: #555;
  margin-top: 10px;
}

.weekserve-img {
  width: 260px;
  margin: 0 auto 30px auto;
}

.couponBox .weekserve-container .btn {
  display: block;
  color: white;
  margin-top: 20px;
  width: 100%;
  padding-top: 12px;
  padding-bottom: 12px;
  font-size: 16px;
  border-radius: 5px;
}

.btn-mod.btn-w {
    background: #f5f5f5 !important;
        color: #1D1D1F!important;
}




.couponBox .precautions-content {
  max-width: 900px;
  margin: 0 auto;
  text-align: left;
}

.couponBox .precautions-content article {
  margin-bottom: 40px;
}

.couponBox .precautions-content h3 {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 8px;
}

.couponBox .precautions-content p {
  line-height: 28px;
  font-size: 16px;
}



.join-week .grid-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  /* max-width: 900px; */
  width: 85%;
  margin: 0 auto;
}

.join-week .grid-item {
  background: #fff;
  padding: 38px 56px;
}

.join-week strong {
  font-size: 20px;
  font-weight: 900;
  color: #1D1D1F;
  letter-spacing: 1px;
}

.join-week h4 {
  font-size: 24px;
    font-weight: 800;
    text-align: center;
    margin-bottom: 30px;
}

.join-week p {
      font-size: 16px;
    margin-bottom: 14px;
    color: #555;
}

.join-week .join-week-img {
    margin: 32px auto 20px auto;
}

.join-week .join-week-img img {
    width: 300px;
}

.join-week .btn {
  display: block;
  color: white;
  margin-top: 40px;
  width: 100%;
  padding-top: 16px;
  padding-bottom: 16px;
  font-size: 18px;
}

.join-week .btn span {
  font-weight: 800;
}

.join-week .weekserve-container .btn {
  margin-top: 12px;
  font-size: 18px;
  padding-top: 16px;
  padding-bottom: 16px;
}

.join-week .qr-code {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 64px;
}

.join-week .app-links img {
  width: 120px;
  margin-top: 5px;
}

.join-week .qr-code .qr-item-l img {
  width: 180px;
}

.join-week .qr-code .qr-item-r img {
  display: block;
  width: 150px;
}

.join-week .qr-code .qr-item-r a {
  transition: all 0.3s ease;
}
.join-week .qr-code .qr-item-r a:hover {
  opacity: 0.8;
}

.join-week .qr-code .qr-item-r p {
  margin-bottom: 8px;
  font-weight: 700;
}

.join-week .qr-code .qr-item-r img.download-btn {
  margin-bottom: 8px;
}

.bg-grey {
  background: #F5F5F5;
}

.activity-box img{
  width: 100%;
  margin-bottom: 24px;
}




.food-button {
  border: 1px solid #3c3c43;
  cursor: pointer;
  text-align: center;
  /* width: max-content; */
  margin: auto;
  width: 450px;
  /* height: 120px; */
  padding: 10px 0px;
  /* background-color: #f0f0f0; */
}

.food-button:hover {
  background-color: #f0f0f0;
}

.food-button.f-btn-bg {
  border: none;
  background-color: #f0f0f0;
}

.food-button.f-btn-bg:hover {
  opacity: 0.8;
}

.food-button div:first-child {
  width: 33%;
}
.food-button div:nth-child(2) {
  width: 55%;
}
.food-button div:last-child {
  width: 8%;
}


.food_ttl {
  font-size: 18px!important;
  font-weight: 700;
  color: #222;
  text-align: left;
}

.food-txt {
  font-size: 15px;
  color: #222;
  text-align: left;
}

.minHeight-45{
  height: 45px;
}

.minHeight-70{
  height: 55px;
}


.cjbflexitem{
  padding: 0px!important;
}

.sf-simpleBff_productsItemColorChips {
  min-height: 20px;
}


.alt-features-title::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background-image: url("../images/ico_arrow_down-y.svg");
  background-size: contain;
  background-repeat: no-repeat;
  margin: 16px auto 2px;
  transition: transform 0.3s ease;
}

.alt-features-title:hover::after {
  transform: translateY(3px);
}



.weekserve-container{
  width: 85%;
    margin: 20px auto 0px auto;
}

.weekserve-container .weekserve-box{
  background-color: #FFF;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 20px;
}


.weekserve-box .weekserve-text strong{
  font-size: 20px;
  font-weight: 900;
  color: #1D1D1F;
}

.weekserve-box .weekserve-text h3{
  font-size: 32px;
  font-weight: 800;
  text-align: left;
  margin-top: 2px;
  margin-bottom: 12px;
  color: #1D1D1F;
  letter-spacing: 1px;
  line-height: 36px;
}

.weekserve-box .weekserve-text h4{
  font-size: 20px;
  font-weight: 800;
  color: #1D1D1F;
  letter-spacing: 1px;

}

.weekserve-box .weekserve-text p{
  font-size: 15px;
  margin-bottom: 0px;
  color: #000000;
}

.weekserve-box .weekserve-text{
  position: relative;
}


.weekserve-container .weekserve-box .weekserve-item:first-child{
  width: 50%;
  height: 400px;
  overflow: hidden;
}


.weekserve-container .weekserve-box .weekserve-item:first-child img{
  height: 100%;
  width: 100%;
  object-fit: cover;     /* 保持圖片比例並填滿容器，超出的會裁切 */
  object-position: center; /* 圖片中心對齊，可改 top / bottom 看你喜好 */
  display: block;
}


img.badgeimg{
  position: absolute;
  top: 10rem;
  left: 16rem;
  z-index: -1;
  opacity: 0.6;
  width: 100px;

}

.weekserve-box .act-sub-title h4 {
  font-size: 28px;
  letter-spacing: 1px;
  font-weight: 900;
  color: #1D1D1F;
}

.weekserve-box .act-sub-title h4 b{
  background: #7F0019;
  color: #fff;
  padding: 7px 8px;
  border-radius: 100%;
  margin-right: 5px;
}


.markupBox {
  position: relative;
}

.markupBox .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  font-size: 24px;
  font-weight: bold;    z-index: 999;
}

.markupBox .overlay span{
  font-size: 40px;
}

/* .activity-accordion .toggle > dt > a:after {
  content: '+';
  top: 45%;
  right: 40%;
  font-size: 32px !important;
}

.toggle > dt > a.active:after,
.toggle > dt > a.active:hover:after {
  transform: translateY(-50%) rotate(180deg) !important;
}
.activity-accordion .toggle > dt > a.active:after,
.toggle > dt > a.active:hover:after {
  content: '-';
  top: 52%;
} */

.activity-accordion .toggle h4 {
  font-size: 20px;
  font-weight: 900;
}

.activity-accordion .toggle > dd {
  font-size: 16px;
}

.activity-accordion .toggle > dd ol {
  list-style: auto;
}

.couponBox .work-title {
  background: #e0ceaa;
  padding: 9px;
  font-size: 15px;
  font-weight: 600;
  border-radius: 8px;
  position: relative;
}

.couponBox .work-title::after {
  position: absolute;
  content: '';
  width: 0;
  height: 0;
  top: -12px;
  left: 45%;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-bottom: 16px solid #e0ceaa;
}

.couponBox .work-intro {
  padding: 25px 10px 0px 10px;
}

.couponBox .activity-title {
  width: 300px;
}

.couponBox h3 {
  font-size: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 0.75px;
}

.couponBox h3 span {
  font-size: 40px;
  color: #7f0019;
}


.couponBox h3 span.sale-num{
      font-size: 30px;
    font-weight: 900;
}

.couponBox h3 span.sale-num b{
      font-size: 34px;
}

.couponBox .titleTop h3{
  letter-spacing: 0.75px;
}

p .label-s {
  color: #3c3c43;
  background: #e0ceaa;
  font-size: 20px;
  padding: 3px 8px;
  border-radius: 2px;
  margin-right: 10px;
}

.line {
  width: 4px;
  background-color: darkred;
  position: absolute;
  transform-origin: bottom;
}

.line1 {
  height: 50px;
  left: 30%;
  top: 22px;
  transform: rotate(-28deg);
  animation: stretch1 1s infinite alternate;
}

.line2 {
  height: 100px;
  left: 28%;
  top: -16px;
  transform: rotate(-45deg);
  animation: stretch2 1s infinite alternate;
}

.line3 {
  height: 50px;
  right: 30%;
  top: 22px;
  transform: rotate(28deg);
  animation: stretch3 1s infinite alternate;
}

.line4 {
  height: 100px;
  right: 28%;
  top: -16px;
  transform: rotate(45deg);
  animation: stretch4 1s infinite alternate;
}

@keyframes stretch1 {
  0% {
    transform: rotate(-28deg) scaleY(1);
  }
  100% {
    transform: rotate(-28deg) scaleY(0.8);
  }
}

@keyframes stretch2 {
  0% {
    transform: rotate(-45deg) scaleY(1);
  }
  100% {
    transform: rotate(-45deg) scaleY(0.8);
  }
}

@keyframes stretch3 {
  0% {
    transform: rotate(28deg) scaleY(1);
  }
  100% {
    transform: rotate(28deg) scaleY(0.8);
  }
}

@keyframes stretch4 {
  0% {
    transform: rotate(45deg) scaleY(1);
  }
  100% {
    transform: rotate(45deg) scaleY(0.8);
  }
}

.lineLeftT {
  height: 35px;
  left: 37%;
  top: -18px;
  transform: rotate(290deg);
  animation: lineLeftT1 1s infinite alternate;
}
.lineLeftB {
  height: 35px;
  left: 37%;
  bottom: 16px;
  transform: rotate(250deg);
  animation: lineLeftT2 1s infinite alternate;
}

.lineRightT {
  height: 35px;
  right: 37%;
  top: -18px;
  transform: rotate(-290deg);
  animation: lineRightT1 1s infinite alternate;
}
.lineRightB {
  height: 35px;
  right: 37%;
  bottom: 16px;
  transform: rotate(-250deg);
  animation: lineRightT2 1s infinite alternate;
}

@keyframes lineLeftT1 {
  0% {
    transform: rotate(290deg) scaleY(1);
  }
  100% {
    transform: rotate(290deg) scaleY(0.8);
  }
}
@keyframes lineLeftT2 {
  0% {
    transform: rotate(250deg) scaleY(1);
  }
  100% {
    transform: rotate(250deg) scaleY(0.8);
  }
}
@keyframes lineRightT1 {
  0% {
    transform: rotate(-290deg) scaleY(1);
  }
  100% {
    transform: rotate(-290deg) scaleY(0.8);
  }
}
@keyframes lineRightT2 {
  0% {
    transform: rotate(-250deg) scaleY(1);
  }
  100% {
    transform: rotate(-250deg) scaleY(0.8);
  }
}

.parallax-mousemove-scene img{
  width: 100%;
}


.sf-simpleBff_productsItemHeading{
  font-size: 14px;
  line-height: 22px;
  margin: 10px 0px;
}

.sf-simpleBff_productsItemColorChips{
  margin-bottom: 0px;
  gap: 6px 1px;
  padding: 0px 0px!important;
}

.sf-simpleBff_productsItemColorChip {
  height: 19px;
  width: 19px;
}

.mark_btn {
  position: absolute;
  top: 0px;
  left: 0px;
  display: inline-block;
  padding: 0.25rem 0.5rem;
  background-color: #7f0019;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
}


.productList {
  display: flex;
  flex-wrap: wrap;
  /* justify-content: center; */
  gap: 10px;
  padding: 0 0px;
  width: 100%;
}
.productList .productItem {
  width: calc(25% - 10px);
}

.productList .productItem.proCol-2{
  width: calc(50% - 10px);

}

.productList.proCol-5{
  /* justify-content: center; */
  gap: 20px;
}
.productList.proCol-5 .productItem{
  width: calc(16.666% - 20px);
}


.call-action-4-image-2.clothesText {
  background: #fff;
  z-index: 990;
  width: 33%;
  height: auto;
  bottom: 10%;
  padding: 3rem 1.75rem;
}

.newText {
  font-size: 30px;
  font-weight: 700;
}

ul.tag-category {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 0 20px;
  font-size: 13px;
  flex-wrap: wrap;
  width: 80%;
  margin: 1rem auto;
}

ul.tag-category li {
  padding: 2px 8px;
  font-weight: 600;
}

ul.tag-category li:nth-child(1) {
  background: #e3b34d;
}
ul.tag-category li:nth-child(2) {
  background: #d8b58b;
}
ul.tag-category li:nth-child(3) {
  background: #d9bcb7;
}
ul.tag-category li:nth-child(4) {
  background: #6c745d;
}
ul.tag-category li:nth-child(4) a {
  color: #fff;
}

.markupBox {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin: 20px auto;
  padding: 2rem 10rem;
  position: relative;
}

.recommend-icon {
  position: absolute;
  top: -20px;
  right: 100px;
  color: var(-color-dark-1);
  pointer-events: none;
}

.text-container {
  flex: 2;
  padding-right: 20px;
}

.img-container {
  flex: 1;
  text-align: center;
}

.img-container img {
  max-width: 100%;
  height: auto;
}


.motherAD-img{
  width: 80%;
  margin: 40px auto 60px auto;
}





@media (max-width: 768px) {


  .cjbflexitem{
    padding: 0px 20px!important;
  }

  .join-week .grid-container,
  .weekserve-container .grid-container {
    grid-template-columns: 1fr; /* 讓項目單行排列 */
  }

  .join-week .grid-container,.couponBox .weekserve-container{
    width: 90%;
  }

  .weekserve-container .join-week .grid-container {
    width: 88%;
  }


  .markupBox {
    flex-direction: column;
  }
  .img-container {
    order: -1;
  }

  .text-container {
    padding-right: 0;
    padding-bottom: 20px;
  }


  .saleBox {
    scroll-snap-align: start;
    padding: 8px 0;
  }

  .row.saleCoupon {
    margin-left: 0 !important;
    margin-right: 0 !important;
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    display: flex;
    justify-content: flex-start;
    gap: 0px;
  }


  .weekserve-container .weekserve-box .weekserve-item:first-child {
    width: 100%;
  }

  .weekserve-box .weekserve-text h4 {
    font-size: 16px;
  }

  .food-button {
    border: 1px solid #3c3c43;
    cursor: pointer;
    text-align: center;
    margin: auto;
    width: 360px;
    padding: 10px 8px;
  }


  .menu ul {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    gap: 0px;
    margin: 0;
  }

  .menu ul li {
    flex: 0 0 auto;
    white-space: nowrap;
  }


  .weekserve-box .weekserve-text h3{
    font-size: 28px;
  }

  .weekserve-box .weekserve-text .act-sub-title h4 {
    font-size: 28px;
  }


  /* .menu a::after {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    background-image: url(../images/ico_arrow_down-y.svg);
    background-size: contain;
    background-repeat: no-repeat;
    margin: 6px auto 2px;
    transition: transform 0.3s ease;
}

 */
 .menu ul li:not(:first-child):before {
  content: "";
  position: absolute;
  left: -1px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 45px;
  background-color: #d8d8d9
}


.celebrate-box h3.title-week{
  margin: 40px 0px 0px 0px;
}

h3.title-week{
  margin: 40px 0px;
}


  .couponBox .weekserve-container .grid-container {
    grid-template-columns: 1fr;
    width: 90%;
  }

  .weekserve-container{
    width: 90%;
  }

  .weekserve-container .weekserve-box{
    display: block;

  }

  .weekserve-box .weekserve-text {
    margin-top: 24px;
  }

  img.badgeimg {
    position: absolute;
    top: 11rem;
    left: 14.5rem;
    width: 90px;
  }


}

img.vector {
  position: relative;
  top: 10px;
  left: 20px;
}

@keyframes blink {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}

img.subtract {
  width: 38px;
  position: absolute;
  bottom: 2%;
  animation: blink 2s ease-in-out infinite;
}

img.subtract.subtract-l {
  left: 34%;
}
img.subtract.subtract-r {
  right: 33%;
}

.tabBox h4.post-prev-title {
  padding: 0;
}

.tabBox .post-prev-img {
  margin-bottom: 10px;
  border-radius: 0;
}

.tabBox .post-prev-container:before {
  display: none;
}
.tabBox h4.post-prev-title {
  font-size: 16px;
  position: relative;
  font-weight: 600;
}

.couponBox h3.post-prev-2-title {
  font-size: 20px;
  position: relative;
  font-weight: 600;
}

.couponBox h3.post-prev-2-title span {
  font-size: 20px;
  background-color: #f4eede;
  color: var(--color-dark-1);
  padding: 4px 8px;
  margin-right: 10px;
  vertical-align: middle;
}

.couponBox h3.post-prev-2-title b span {
  font-size: 22px;
  background: none;
  color: #7f0019;
  padding: 0px 1px;
  margin-right: 0px;
  position: relative;
  bottom: 2px;
}

.couponBox h3.post-prev-2-title span.webCart {
  background-color: #7f0019;
  color: #fff;
}

.couponBox .post-prev-2-img {
  margin-bottom: 10px;
}

.tabBox .nav-tabs {
  display: flex;
  justify-content: space-between;
}

.tabBox .nav-item {
  flex: 1;
  text-align: center;
}

.tabBox .nav-link {
  display: block;
  padding: 0.5rem 1rem;
  color: #0d6efd;
  text-decoration: none;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out;
}

.tabBox .nav-tabs .nav-link {
  margin-bottom: -1px;
  background: 0 0;
  border: 1px solid transparent;
  border-bottom: none;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  background: #ebebec;
  font-weight: 600;
  font-size: 16px;
}

.tabBox .tpl-tabs > li > .nav-link.active {
  border-top: 2px solid #e0ceaa;
  color: var(--color-dark-1) !important;
}

.tabBox .tab-content {
  border-top: 1px solid rgb(221, 221, 221);
  margin-top: -1px;
  padding-top: 3rem;
}

.tabBox .container {
  /* padding-left: 64px; */
  /* padding-right: 64px; */
}
.tabBox .tab-pane {
  /* margin-left: auto;
  margin-right: auto;
  padding-left: 64px;
  padding-right: 64px;
  max-width: 1320px; */
}

.feedbackBox h3 {
  font-size: 28px;
  position: relative;
  font-weight: 900;
  line-height: 1.5;
}

.bubbleBox {
  display: flex;
  flex-wrap: wrap;
}

.bubbleBox .buCol {
  /* padding: 1.25rem 0; */
  margin: 2rem 0;
  display: flex;
  justify-content: flex-start;
}

.bubbleBox .buCol:nth-child(1) {
  justify-content: flex-end;
  align-items: flex-end;
  padding-right: 4rem;
  margin-bottom: 0px;
}

.bubbleBox .buCol:nth-child(2) {
  margin-top: 0px;
  padding-left: 1rem;
}

.bubbleBox .buCol:nth-child(3) {
  justify-content: flex-end;
  align-items: flex-end;
  padding-right: 1rem;
  margin-bottom: 0px;
}

.bubbleBox .buCol:nth-child(4) {
  padding-left: 4rem;
}

.bubbleBox .buCol:nth-child(5) {
  justify-content: flex-end;
  align-items: flex-end;
  padding-right: 8rem;
  margin-bottom: 0px;
}

.speech-bubble {
  padding: 15px 20px;
  background-color: #f3f3f3;
  position: relative;
  font-size: 14px;
  color: #333;
  display: flex;
  align-items: center;
}

.speech-bubble.bor-l {
  border-radius: 10px 10px 0px 10px;
}
.speech-bubble.bor-r {
  border-radius: 10px 10px 10px 0px;
}

.bubble1 {
  background-color: #eac0ca;
  max-width: 390px;
}
.bubble2 {
  background-color: #d6e3a2;
  max-width: 280px;
}
.bubble3 {
  background-color: #ebd5ab;
  max-width: 390px;
}
.bubble4 {
  background-color: #c4dced;
  max-width: 330px;
  max-height: 75px;
}
.bubble5 {
  background-color: #f3bfb3;
  max-width: 390px;
}
.bubble6 {
  background-color: #d3c1cd;
  max-width: 390px;
}

.speech-bubble span {
  display: flex;
  vertical-align: middle;

  font-size: 16px;
}

.speech-bubble span:first-child {
  margin-right: 15px;
}

img.people-icon {
  max-width: 90px !important;
}

.call-action-4-image-1 img {
  width: 100%;
}

.sf-commonBanner_items {
  padding: 0px;
}

.sf-button.-secondary {
  background-color: #f4eede;
  border: 1px solid #f4eede;
  color: #666;
  font-weight: 600;
}

.sf-button.-secondary:hover {
  background-color: #e0ceaa;
  border: 1px solid #e0ceaa;
}

.commitem_text {
  font-size: 14px;
  color: #666;
}

.home-content h1 {
  font-weight: 900;
  font-size: 50px;
  line-height: 1.5;
}
.banner-container {
  position: relative;
  width: 600px;
  height: 200px;
}

.curve {
  position: absolute;
  width: 360px;
}

.curve.lag-line-l {
  top: -1%;
  left: -1%;
}
.curve.lag-line-r {
  top: -1%;
  right: -1%;
}

.one-year-images img {
  width: 400px;
  z-index: 9999;
  position: relative;
}

.lottie-container {
  opacity: 0.8;
  position: absolute;
  top: -20%;
  left: 25%;
}

@keyframes fadeIn {
  0% {
    opacity: 0.8;
  }
  100% {
    opacity: 1;
  }
}

.lottie-container #myPlayer {
  width: 800px;
  height: 800px;
}

.post-prev-2-title a {
  position: absolute;
}

img.bn-icon-1 {
  width: 260px;
  position: absolute;
  bottom: 20%;
  left: 10%;
}
img.bn-icon-2 {
  width: 330px;
  position: absolute;
  bottom: 33%;
  right: 8%;
}

img.bn-icon-m-1 {
  width: 105px;
  position: absolute;
  bottom: 41%;
  left: 3%;
}
img.bn-icon-m-2 {
  width: 105px;
  position: absolute;
  bottom: 35%;
  right: 2%;
}

#home .bnText p {
  font-size: 18px;
  font-weight: 900;
  color: #1d1d1f;
  background: #f4eede;
  margin: 0px;
  border-radius: 5px;
  padding: 10px;
}

#home .pb-sm-120 {
  padding-bottom: 60px !important;
}

.backToUp {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999;
  color: #fff;
  border-radius: 50%;
  padding: 10px;
  cursor: pointer;
}

.link-to-top i {
  color: #7f0019;
  transform: rotate(0deg) translateZ(0);
  transition: transform 0.5s ease-in-out;
}

.link-to-top:before {
  background: none;
  border: 1px solid #7f0019;
}

.link-to-top:hover i {
  transform: rotate(360deg) translateZ(0);
}

.home-section {
  z-index: 9999;
  overflow: hidden;
  position: relative;
}


.home-text {
  position: absolute;
    top: 16%;
    left: 10%;
    color: #fff;
    z-index: 10;
}

.home-text p {
  writing-mode: vertical-rl;
  transform: rotate(360deg);
  font-size: 40px;
  font-weight: 900;
  line-height: 50px;
  letter-spacing: 10px;
}

.kv-section{
  position: relative;
}

.kv-text {
  position: absolute;
    top: 18%;
    left: 14%;
    color: #000;
    z-index: 10;
}

.kv-text p {
  writing-mode: vertical-rl;
  transform: rotate(360deg);
  font-size: 40px;
  font-weight: 900;
  line-height: 50px;
  letter-spacing: 10px;
}

#about img{
  width: 100%;
}



.sf-u-contents_desktop {
  /* margin-left: auto; */
  /* margin-right: auto; */
  /* max-width: calc(1072px + var(--space-h-s) + var(--space-h-s)); */
  /* padding-left: var(--space-h-s); */
  /* padding-right: var(--space-h-s); */
  max-width: var(--container-width);
  padding: 0 45px;
  margin: var(--space-v-xxxxl) auto;
}

/* alert */
.alert-overlay {
  display: none; /* 默認不顯示 */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5); /* 黑色透明 */
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

/* 彈出框 */
.alert-box {
  position: relative;
  background-color: white;
  padding: 20px;
  border-radius: 10px;
  text-align: center;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  width: 300px;
}

/* 右上角的 X 按鈕 */
.close-btn {
  position: absolute;
  top: 10px;
  right: 15px;
  font-size: 20px;
  cursor: pointer;
  color: #555;
}

.close-btn:hover {
  color: #e74c3c;
}

/* 彈出框內按鈕 */
.alert-box button {
  padding: 10px 20px;
  margin-top: 10px;
  background-color: #3498db;
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}

.alert-box button:hover {
  background-color: #2980b9;
}

@media (min-width: 1061px) and (max-width: 1119px) {
  .PConly {
    display: none !important;
  }
  .Mobonly {
    display: block !important;
  }
  .curve {
    position: absolute;
    width: 160px;
  }

  .services-tabs > li {
    margin-bottom: 0.75rem !important;
  }
  .page-section,
  .split-column-left,
  .split-column-right {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  #about.page-section {
    padding-top: 70px !important;
  }

  .sf-u-contents_desktop {
    padding: 0 20px;
  }

  .bubbleBox .buCol:nth-child(5) {
    padding-right: 4rem;
  }

  #activity-1 .section-title-tiny {
    font-size: 20px;
  }
  #activity-1 .p-5 {
    padding: 1.2rem !important;
  }
  #activity-3 h3 {
    font-size: 30px;
  }
  #services .section-title {
    font-size: 30px;
  }

  .menu ul {
    display: flex;
    margin: 0;
    padding: 0.5rem;
    align-items: center;
    overflow-x: auto;
    white-space: nowrap;
    /* scroll-behavior: smooth; */
  }

  .menu ul li {
    flex: 0 0 auto;
    min-width: 160px;
    text-align: center;
    position: relative;
  }

  .menu ul::-webkit-scrollbar {
    display: none;
  }

  .menu a {
    font-size: 16px;
  }

  .feedbackBox h3 {
    font-size: 24px;
  }
  .couponBox h3.post-prev-2-title {
    font-size: 18px;
    margin-bottom: 2.5rem;
  }

  .one-year-images img {
    width: 260px;
  }

  .lottie-container {
    top: -5%;
    left: -15%;
  }

  .lottie-container #myPlayer {
    width: 500px;
    height: 500px;
  }
  .home-content h1 {
    font-size: 38px;
  }

  .saleCoupon .saleBox {
    display: flex;
    width: 50%;
  }
  img.ribbons {
    width: 60px;
  }
  .saleCoupon .alt-features-item.box-shadow {
    padding: 30px 10px;
    min-width: 160px;
    height: 160px;
  }
  .alt-features-title {
    font-size: 18px !important;
    line-height: 1.5;
  }

  .couponBox h3 {
    font-size: 26px;
  }
  .couponBox h3 span {
    font-size: 33px;
    color: #7f0019;
  }

  .line1 {
    left: -1%;
    top: 22px;
  }
  .line2 {
    left: -2%;
    top: -16px;
  }
  .line3 {
    right: -1%;
    top: 22px;
  }
  .line4 {
    right: -2%;
    top: -16px;
  }

  .call-action-4-image-2 {
    position: relative !important;
  }
  .couponBox .call-action-4-image-1 {
    width: 100%;
  }

  .call-action-4-image-2.clothesText {
    background: #fff;
    z-index: 990;
    width: 100%;
    height: auto;
    bottom: 10%;
    padding: 0rem;
    margin-top: 2rem;
  }

  .img-container img {
    width: 75% !important;
  }
  .productList .productItem {
    width: calc(50% - 20px);
  }

  .lineLeftT {
    left: 35%;
    top: -20px;
  }
  .lineLeftB {
    left: 35%;
    bottom: 12px;
  }

  .lineRightT {
    right: 35%;
    top: -20px;
  }
  .lineRightB {
    right: 35%;
    bottom: 12px;
  }

  .markupBox {
    padding: 2rem 5rem;
  }

  .productList {
    gap: 15px;
    padding: 0 0px;
  }

  .recommend-icon {
    top: -12px;
    right: -5px;
    width: 115px;
  }

  .recommend-icon img {
    width: 120px;
  }

  img.subtract {
    width: 20px;
    bottom: -5%;
  }
  img.subtract.subtract-l {
    left: 0%;
  }
  img.subtract.subtract-r {
    right: 0%;
  }

  .tabBox .container {
    padding-left: 15px;
    padding-right: 15px;
  }
  .tabBox .nav-link {
    padding: 0.5rem 0.5rem;
  }

  .tpl-tabs li .nav-link.active {
    border-radius: 0px !important;
  }
  .tabBox .tab-pane {
    padding-left: 10px;
    padding-right: 10px;
  }

  .tabBox .post-prev {
    width: 20%;
  }

  .bubbleBox .buCol:nth-child(1) {
    padding-right: 1rem;
    margin-bottom: 2rem;
  }
  .bubbleBox .buCol:nth-child(3) {
    margin-top: 0rem;
    margin-bottom: 0px;
  }
  .bubbleBox .buCol:nth-child(4) {
    margin-bottom: 0px;
  }
  .services-tabs > li > a {
    font-weight: 700;
    font-size: 22px;
  }
  .categoryList {
    width: 23%;
  }

  .categoryList .categoryR {
    width: 65%;
  }
}
@media screen and (max-width: 750px) {
  .PConly {
    display: none !important;
  }
  .Mobonly {
    display: block !important;
  }
  .curve {
    position: absolute;
    width: 160px;
  }





  img.bn-icon-m-1 {
    width: 105px;
    position: absolute;
    bottom: 38%;
    left: 3%;
  }

  /* .activity-accordion .toggle > dt > a.active:after,
  .toggle > dt > a.active:hover:after {
    content: '-';
    top: 52%;
    right: 23%;
    font-size: 40px !important;
  } */

  .services-tabs > li {
    margin-bottom: 0.75rem !important;
  }
  .page-section,
  .split-column-left,
  .split-column-right {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }

  #about.page-section {
    padding-top: 40px !important;
  }

  .titleTop.mb-sm-50{
    margin-bottom: 30px!important;
  }
  .sf-u-contents_desktop {
    padding: 0 20px;
  }

  .bubbleBox .buCol:nth-child(5) {
    padding-right: 4rem;
  }

  #activity-1 .section-title-tiny,
  #activity-3 .section-title-tiny {
    font-size: 20px;
    line-height: 40px;
  }
  #activity-1 .p-5,
  #activity-8 {
    padding: 4rem 1.2rem 1.2rem 1.2rem !important;
  }
  #activity-3 h3 {
    font-size: 30px;
  }

  #services .section-title {
    font-size: 30px;
  }

  .menu ul {
    display: flex;
    margin: 0;
    padding: 0.5rem 0.5rem 0 0.5rem;
    align-items: center;
    /* overflow-x: auto; */
    /* white-space: nowrap; */
    /* scroll-behavior: smooth; */
  }

  .menu ul li {
    flex: 0 0 auto;
    /* min-width: 160px; */
    padding: 6px 0;
    text-align: center;
    position: relative;
    border-bottom: 2px solid transparent;
  }

  .menu li:not(:last-child)::after{
    display: none;
  }

  .menu ul::-webkit-scrollbar {
    display: none;
  }

  .menu a {
    font-size: 15px;
    padding: 0.5rem 0rem;
  }

  .couponBox{
    padding-top: 40px!important;
  }

  .section-title-small{
    margin-top: 20px!important;
    margin-bottom: 8px!important;
  }

  .productList.proCol-5 {
    justify-content: space-between;
    gap: 12px;
  }

  .productList.proCol-5 .productItem {
    width: calc(50% - 12px);
  }

  .section-title-small.mbtitle{
    margin-bottom: 20px !important;
  }

  .boxTopMar{
    margin-top: 60px!important;
  }

  .mt-80.Mb0{
    margin-top: 0px!important;
  }

  #about .saleBox {
    width: auto;
    padding: 10px 28px;
}

  .feedbackBox h3 {
    font-size: 24px;
  }
  .couponBox h3.post-prev-2-title {
    font-size: 18px;
    margin-bottom: 2.5rem;
  }

  .one-year-images img {
    width: 260px;
  }

  .lottie-container {
    top: -5%;
    left: -15%;
  }

  .lottie-container #myPlayer {
    width: 500px;
    height: 500px;
  }
  .home-content h1 {
    font-size: 38px;
  }

  .saleCoupon .saleBox {
    display: flex;
    width: 50%;
  }
  img.ribbons {
    width: 60px;
  }
  .saleCoupon .alt-features-item.box-shadow {
    padding: 30px 10px;
    min-width: 160px;
    height: 160px;
  }
  .alt-features-title {
    font-size: 15px !important;
    line-height: 1.5;
  }

  .couponBox h3 {
    font-size: 26px;
  }
  .couponBox h3 span {
    font-size: 26px;
    color: #7f0019;
  }

  .line1 {
    left: -1%;
    top: 22px;
  }
  .line2 {
    left: -2%;
    top: -16px;
  }
  .line3 {
    right: -1%;
    top: 22px;
  }
  .line4 {
    right: -2%;
    top: -16px;
  }

  /* .activity-accordion .toggle > dt > a:after {
    content: '+';
    top: 42%;
    right: 24%;
  } */

  .call-action-4-image-2 {
    position: relative !important;
  }
  .couponBox .call-action-4-image-1 {
    width: 100%;
  }

  .call-action-4-image-2.clothesText {
    background: #fff;
    z-index: 990;
    width: 100%;
    height: auto;
    bottom: 10%;
    padding: 0rem;
  }

  .img-container img {
    width: 75% !important;
  }
  .productList .productItem {
    width: calc(50% - 20px);
  }

  .lineLeftT {
    left: 15%;
    top: -20px;
  }
  .lineLeftB {
    left: 15%;
    bottom: 12px;
  }

  .lineRightT {
    right: 15%;
    top: -20px;
  }
  .lineRightB {
    right: 15%;
    bottom: 12px;
  }

  .markupBox {
    padding: 1rem 1rem;
  }

  .productList {
    gap: 15px;
    padding: 0 0px;
  }

  .recommend-icon {
    top: -12px;
    right: -5px;
    width: 115px;
  }

  .recommend-icon img {
    width: 120px;
  }

  img.subtract {
    width: 20px;
    bottom: -5%;
  }
  img.subtract.subtract-l {
    left: 0%;
  }
  img.subtract.subtract-r {
    right: 0%;
  }

  .tabBox .container {
    padding-left: 15px;
    padding-right: 15px;
  }
  .tabBox .nav-link {
    padding: 0.5rem 0.5rem;
  }

  .tpl-tabs li .nav-link.active {
    border-radius: 0px !important;
  }
  .tabBox .tab-pane {
    padding-left: 10px;
    padding-right: 10px;
  }

  .tabBox .post-prev {
    width: 50%;
  }

  .bubbleBox .buCol:nth-child(1) {
    padding-right: 1rem;
    margin-bottom: 2rem;
  }
  .bubbleBox .buCol:nth-child(3) {
    margin-top: 0rem;
    margin-bottom: 0px;
  }
  .bubbleBox .buCol:nth-child(4) {
    margin-bottom: 0px;
  }
  .services-tabs > li > a {
    font-weight: 700;
    font-size: 22px;
  }
  .categoryList {
    width: 100%;
  }

  .categoryList .categoryR {
    width: 65%;
  }


  .home-text p {
    writing-mode: vertical-rl;
    transform: rotate(360deg);
    font-size: 26px;
    font-weight: 900;
    line-height: 40px;
    letter-spacing: 6px;
  }
  .home-text {
    position: absolute;
    top: 9%;
    left: 11%;
    color: #fff;
    z-index: 10;
}

.kv-text p {
  font-size: 34px;
  line-height: 24px;
  letter-spacing: 5px;
}


.kv-text {
  position: absolute;
  top: 12%;
  left: 12%;
  color: #000;
  z-index: 10;
}

.motherAD-img{
  width: 100%;
  margin: 20px auto 40px auto;
}



.passport-flex {
    display: block;
    width: 100%;
  }
  .passport-flex .passport-item-l {
    width: 100%;
  }
  .passport-flex .passport-item-r {
    width: 100%;
  }

  .weekserve-img {
    width: 100%;
    margin: 0 auto 30px auto;
  }


  .join-week .weekserve-container .grid-item {
    padding: 18px 0px;
  }

  .join-week .grid-item {
    padding: 30px 28px;
  }

  .join-week h4 {
    font-size: 20px;
    margin-bottom: 18px;
  }

  .weekserve-container h4 {
    font-size: 24x;
    margin-bottom: 18px;
  }

  .weekserve-container h3 {
    font-size: 20px;
  }

  .weekserve-container {
    width: 88%;
    padding: 50px 10px;
  }

  .celebrate-box .title-week {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative; /* 設定基準點 */
  }

  .celebrate-box .title-week b.muji_color {
    display: block;
  }

  .celebrate-box .title-week::before,
  .celebrate-box .title-week::after {
    position: absolute;
    width: 65px;
    height: 3px;
  }

  .celebrate-box .title-week::before {
    transform: rotate(50deg);
    left: -35px;
    top: 75%;
  }

  .celebrate-box .title-week::after {
    transform: rotate(-50deg);
    right: -35px;
    top: 75%;
  }


  .card-left {
    width: 60px;
    font-size: 28px;
  }

  .card-right .icon {
    width: 100px;
  }

  .card-right {
    padding: 10px 8px;
  }

  .card-right .text {
    font-size: 18px;
  }

  img.arrow-down {
    position: absolute;
    left: 108px;
    top: 110px;
    width: 18px;
    z-index: 9999;
  }

  .section-title-tiny {
        font-size: 20px;
        text-align: center;
    }




}
