body, div, span, h1, h2, h3, h4, h5, h6 {
    /*font-family: "MicrosoftJhengHeiUI", "\5FAE\8EDF\6B63\9ED1\9AD4", "Microsoft JhengHei" !important;*/
    font-family: Inter, sans-serif !important;
    font-feature-settings: 'liga' 1, 'calt' 1; /* fix for Chrome */
}
button {
  background: transparent;
  box-shadow: 0px 0px 0px transparent;
  border: 0px solid transparent;
  text-shadow: 0px 0px 0px transparent;
}

*[readonly] {
    border: 1px solid #ccc;
    color: #555;
}

button:active {
  outline: none;
  border: none;
}

button:focus {
  outline: 0;
}
ol {
  padding-left: 25px;
}
.font-16 {
  font-size: 16px;
}
.font-18 {
  font-size: 18px;
}
.pb-6 {
  padding-bottom: 4rem!important;
}
.mb-6 {
  margin-bottom: 4rem!important;
}
.mb5 {
  margin-bottom: 5px !important;
}
.mt10 {
  margin-top: 10px;
}
.mt15 {
  margin-top: 15px;
}
.mr0 {
  margin-right: 0 !important;
}
.mr10 {
  margin-right: 10px;
}
.ml10 {
  margin-left: 10px;
}
.pl0 {
  padding-left: 0px !important;
}
.pl5 {
  padding-left: 5px !important;
}
.pl25 {
  padding-left: 25px !important;
}
.pr5 {
  padding-right: 5px !important;
}
.pt10 {
    padding-top: 10px;
}
.pt15{
    padding-top: 15px;
}
.mx-10 {
    margin: 0 10px;
}
.mx-20 {
    margin: 0 20px;
}
.gap-5 {
    gap: 5px;
}
.gap-20 {
    gap: 20px;
}
.gapx-10 {
    gap: 0 10px;
}
.height50 {
  height: 50px !important;
}
.width50 {
  width: 50% !important;
}
.width100 {
  width: 100% !important;
}
.flex-basis-0 {
    flex-basis: 0;
}
.search-area {
    display: inline-block;
    width: 90%;
}
.search-area .form-group{
    margin: 0 !important;
}
a.txt-red {
  color: #c20000;
  text-decoration: underline;
}
.txt-red {
  color: #c20000;
}
.txt-dk-red {
  color: #a10404
}
.txt-underline {
  text-decoration: underline;
}
.opacity-4 {
  opacity: 0.4;
}
.opacity-10 {
  opacity: 1;
}
.ltspc-2 {
  letter-spacing: 2px;
}
.app-img {
  width: 40px;
  border: 1px solid #eee;
  border-radius: 10px;
  vertical-align: bottom;
  margin-left: 5px;
}
.form-group .form-control-icon {
    position: absolute;
    z-index: 11;
    display: block;
    line-height: 2rem;
    margin-left: 12px;
}
.search-area input[type="text"] {
    height: 33px;
    text-indent: 10px;
    border-radius: 20px;
    border: #D1D0D0 solid 1px;
    padding-left: 32px;
}
.jquery-accordion-menu,
.jquery-accordion-menu * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  outline: 0;
}
.jquery-accordion-menu {
  min-width: 260px;
  position: relative;
}
.jquery-accordion-menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.jquery-accordion-menu ul li {
  width: 100%;
  display: block;
  float: left;
  text-align: center;
  border-bottom: 1px dotted #687188;
  line-height: 50px;
}
.jquery-accordion-menu ul li a {
  padding: 14px 22px;
  text-decoration: none;
  font-size: 18px;
  white-space: nowrap;
  overflow: hidden;
  -webkit-transition: color 0.2s linear, background 0.2s linear;
  transition: color 0.2s linear, background 0.2s linear;
  font-weight: 700;
  width: auto;
  position: initial;
  margin: 0 auto;
  float: none;
}
.jquery-accordion-menu ul li a span {
    word-break: break-word;
    white-space: pre-wrap;
}

.jquery-accordion-menu ul li a i {
  width: 34px;
  float: left;
  line-height: 18px;
  font-size: 16px;
  color: #dc3848;
}
.jquery-accordion-menu .submenu-indicator {
  float: right;
  right: 22px;
  position: absolute;
  font-size: 20px;
  -webkit-transition: -webkit-transform 0.3s linear;
  transition: -webkit-transform 0.3s linear;
  transition: transform 0.3s linear;
  transition: transform 0.3s linear, -webkit-transform 0.3s linear;
}

.jquery-accordion-menu .submenu-indicator i{
  color: #dc3848;
  font-size: 16px;
}
.jquery-accordion-menu .submenu-indicator.active {
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg);
}
.jquery-accordion-menu ul ul.submenu .submenu-indicator {
  line-height: 16px;
}
.jquery-accordion-menu .submenu-indicator-minus > .submenu-indicator {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.jquery-accordion-menu ul ul.submenu,
.jquery-accordion-menu ul ul.submenu li ul.submenu {
  width: 0%;
  display: none;
  position: static;
  -webkit-transition: height 0s 500ms, opacity 300ms ease-in-out;
  -moz-transition: height 0s 500ms, opacity 300ms ease-in-out;
       -ms-transition: height 0s 500ms, opacity 300ms ease-in-out;
    -o-transition: height 0s 500ms, opacity 300ms ease-in-out;
   transition: height 0s 500ms, opacity 300ms ease-in-out;
}
.jquery-accordion-menu ul ul.submenu.active {
  display: block;
  width: 100%;
  -webkit-transition: height 0s, opacity 300ms ease-in-out;
  -moz-transition: height 0s, opacity 300ms ease-in-out;
   -ms-transition: height 0s, opacity 300ms ease-in-out;
    -o-transition: height 0s, opacity 300ms ease-in-out;
       transition: height 0s, opacity 300ms ease-in-out;
}
.jquery-accordion-menu ul ul.submenu li {
  clear: both;
  width: 100%;
}
.jquery-accordion-menu ul ul.submenu li a {
  width: 100%;
  float: left;
  background: rgb(237, 28, 36, 0.85);
  border-top: none;
  border-left: 6px solid transparent;
  -webkit-transition: border 0.2s linear;
  transition: border 0.2s linear;
  color: #FFF;
  font-size: 16px;
  height: 58px;
  padding: 5px 22px;
}
.jquery-accordion-menu ul ul.submenu li:hover > a {
  border-left-color: rgb(237, 28, 36, 1);
}
.jquery-accordion-menu ul ul.submenu > li > a {
  padding-left: 30px;
  color: #FFF;
  font-size: 16px;
  border-bottom: 1px dotted;
}
.jquery-accordion-menu ul ul.submenu > li > ul.submenu > li > a {
  padding-left: 45px;
}
.jquery-accordion-menu ul ul.submenu > li > ul.submenu > li > ul.submenu > li > a {
  padding-left: 60px;
}
.jquery-accordion-menu ul li .jquery-accordion-menu-label,
.jquery-accordion-menu ul ul.submenu li .jquery-accordion-menu-label {
  min-width: 20px;
  padding: 1px 2px 1px 1px;
  position: absolute;
  right: 18px;
  top: 14px;
  font-size: 11px;
  font-weight: 800;
  color: #555;
  text-align: center;
  line-height: 18px;
  background: #f0f0f0;
  border-radius: 100%;
}
.jquery-accordion-menu ul ul.submenu li .jquery-accordion-menu-label {
  top: 12px;
}
.header_top {
    padding-bottom: 10px;
    padding-top: 10px;
    position:relative;
    z-index: 10;
    background: #fff;
}
.bottom_header {
    /*margin-bottom: 35px;*/
}
header .menu {
    width: 100%;
    background-color: #f6f6f6;
    margin-bottom: 0;
    list-style-type: none;
    height: 50px;
    font-size: 1.125rem;
    position: absolute;
    top: 0;
    left: 0;
    overflow-x: auto;
    overflow-y: hidden;
    z-index: 4;
}

header .menu .nav li:first-child {
    position: fixed;
    left: 0;
    margin-left: 0px;
    margin-top: 0px;
    width: fit-content;
    background: #f6f6f6;
}

header .open-menu {
    background-color: #fcf8f8;
    width: 42px;
    height: 48px;
    box-shadow: -3px 3px 5px 0px rgba(219,210,210,0.75);
    -webkit-box-shadow: -3px 3px 5px 0px rgba(219,210,210,0.75);
    -moz-box-shadow: -3px 3px 5px 0px rgba(219,210,210,0.75);
    position: absolute;
    top: 0;
    right: 0;
    z-index: 5;
    padding: 0 4px;
    box-sizing: border-box;
}
header .open-menu::before {
    content: "";
    width: 34px;
    height: 34px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cpath fill='%23858585' data-title='Layer 0' d='M28.8 57.6C21.6 59.3 15.3 64.3 12 71l-2 4v5.7c0 5 .1 6.1 1.2 8.7.7 1.6 1.9 4 2.8 5.2.9 1.2 25.2 24.7 54.1 52.2l52.4 50 3.8 1.2c4.6 1.5 7.1 1.3 10.3-.6 3.2-1.9 105.9-100.8 107.9-103.8 2.5-3.9 3.5-7.6 3.5-12.5 0-7.1-2.2-12-7.4-17.1-8.1-7.8-20.9-9-30.4-3.1-1.3.8-18.1 16.7-37.4 35.3-38.5 37.1-37.8 36.5-42.7 35.9-6-.6-4.7.5-42.9-36.1C66 77.5 49.1 61.7 47.8 60.9c-5.2-3.3-13-4.6-19-3.3z'/%3E%3C/svg%3E") no-repeat center/14px;
    border: none;
    transform: unset;
    top: calc(50% - 17px);
    left: calc(50% - 17px);
    position: absolute;
}
header .open-menu.open {
    box-shadow: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
}
header .open-menu.open::before {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256'%3E%3Cpath fill='%23858585' data-title='Layer 0' d='M121.3 57.5c-6.1 1.9-9.1 4.5-57.9 53.5-54.6 54.7-52.9 52.6-53.3 62-.5 9.6 5.1 18.7 14.5 23.6 4 2 5 2.3 10.5 2.3 5.2 0 6.7-.3 9.6-1.9 2.4-1.2 15.2-13.5 43.3-41.6l39.9-39.9 40.4 40.3c38.6 38.5 40.7 40.5 44.8 42 11.8 4.4 24.9-1.7 31-14.3 1.7-3.3 2-5 2-9.4 0-9.8 2.2-7.3-54.4-63.7-47.9-47.9-50.7-50.5-54.7-52-4.4-1.6-12-2-15.7-.9z'/%3E%3C/svg%3E") no-repeat center/14px !important;
}

header .menu li:last-child {
    margin-right: 42px;
}
header .menu li {
    float: none;
    display: inline-block;
    cursor: pointer;
    line-height: 50px;
}
header .menu li .nav-link {
  font-weight: bold;
  padding: 0 .9625rem;
  color: #454545;
}
header .menu li.active .nav-link {
    color: #EB87A0;
    border-bottom: 3px solid #858585;
    max-height: 50px;
}
header .navbar a i.fa-chevron-left {
  font-size: 25px;
  margin-left: 10px;
}
header.white-chevron .navbar a i.fa-chevron-left {
  color: #fff;
}
a[onclick="goBackOrDefault()"] {
  cursor: pointer;
}

header .menu-content {
  background: #fff7ef;
}
header .menu-content .tab-pane {
  overflow: hidden;
  padding-bottom: 10px;
}

header .mobile .banner  {
  width: 100%;
}

header ::-webkit-input-placeholder {
  color: #a0a0a0;
}
header ::-moz-placeholder {
  color: #a0a0a0;
}
header :-ms-input-placeholder {
  color: #a0a0a0;
}
header :-moz-placeholder {
  color: #a0a0a0;
}
header .topmenu {
    width: 100%;
    overflow: hidden;
    border-bottom: 0px;
    transition: all 1ms ease 0ms;
    box-sizing: border-box;
    background: #fafafa;
    position: absolute;
    opacity: 0;
    top: -200px;
    z-index: 3;
}
header .topmenu.open {
    opacity: 1 !important;
    top: 0px !important;
    transition: opacity 300ms ease 280ms;
    z-index: 4 !important;
}
header .topmenu span {
    width: 100%;
    top: 0px;
    display: block;
    height: 50px;
    font: bold 17px/50px Helvetica, sans-serif;
    color: #1D212A;
    margin: 0px;
    padding: 0px 10px;
    position: relative;
    background: #fafafa;
}
header .topmenu ul {
    max-height: calc(100% - 50px);
    overflow-y: scroll;
    padding: 10px 0px;
    margin: 0;
    box-sizing: border-box;
}
header .topmenu ul li {
    width: calc((100% - 48px) / 4);
    float: left;
    text-align: center;
    padding: 0;
    margin: 0 6px 10px 6px;
    box-sizing: border-box;
    list-style: none;
    font-weight: bold;
}

/* 搜尋面板樣式 */
#SearchCover {
    position: fixed;
    width: 100%;
    z-index: 1;
    top: 71px;
    background-color: #fff;
    transition: height 500ms ease;
    box-sizing: border-box;
    overflow: hidden;
    opacity: 0;
    height: 0;
}
#SearchCover.open {
    opacity: 1 !important;
    height: 100vh !important;
    z-index: 2000 !important;
}

#search-panel {
    height: 85vh;
    overflow-y: auto;
}

#search-panel .search-section {
    margin-bottom: 20px;
}

#search-panel .search-section h3 {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 10px;
    color: #333;
}

.search-keywords {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
}

.search-keyword-btn {
    padding: 6px 12px;
    background-color: #f0f0f0;
    border-radius: 15px;
    color: #333;
    font-size: 14px;
    cursor: pointer;
    border: none;
    display: inline-block;
}

.search-keyword-btn:hover {
    background-color: #e0e0e0;
}

.search-keyword-delete {
    font-size: 16px;
    text-align: center;
    cursor: pointer;
}

.search-keyword-delete:hover {
    color: #D38598;
}
.menu-wrapper {
  position: relative;
}

.menu-wrapper .nav {
    display: block;
    white-space: nowrap;
    max-width: 100%;
}

.menu::-webkit-scrollbar {
    height: 5px; /*sets the thickness of horizontal scroll */
}

.menu::-webkit-scrollbar-thumb:horizontal {
    background-color: #9f9c9c;
    border-radius: 10px;
}
.menu-wrapper .menu-content {
  position: absolute;
  top: 50px;
  width: 100%;
  z-index: 100;
}

.main-nav {
  /* background-color: rgba(0, 96, 160, 0.95); */
  /* background-color: rgba(237, 28, 36, 0.9); */
  background-color: #fdfdfd;
  padding: 1rem;
  width: 10rem;
  position: absolute;
  left: -100%;
  -webkit-transition: left 0.35s ease;
  transition: left 0.35s ease;
  z-index: 100;
  width: 100%;
  top: 0;
  height: 100vh;
}
.main-nav i {
  color: #343a40;
  font-size: 24px;
}

.main-nav.show {
  -webkit-transition: left 0.35s ease;
  transition: left 0.35s ease;
  left: 0;
  overflow-y: scroll;
}

.menu-btn i {
    font-size: 28px;
    line-height: 40px;
    vertical-align: middle;
    margin-left: 10px;
    margin-right: 10px;
}
.back-btn i {
    font-size: 28px;
    line-height: 40px;
    vertical-align: middle;
    margin-left: 10px;
    margin-right: 10px;
}
span.rect {
    font-size: 20px;
    color: #fff;
    background: #ed1c24;
    display: inline-block;
    width: 40px;
    text-align: center;
    line-height: 40px;
    vertical-align: bottom;
    margin-left: -5px;
}
button.rect {
  font-size: 20px;
  color: #fff;
  background: #ed1c24;
  display: inline-block;
  width: 40px;
  text-align: center;
  line-height: 39px;
  vertical-align: bottom;
  margin-left: -6px;
  padding-left: 12px;
  z-index: 3;
}
.header_wrap.nav-fixed .hide-scroll {
    display: none;
}
@media only screen and (max-width: 575px) {
  .section.pb_15 {
    padding-bottom: 0px;
    padding-top: 15px;
  }
}
.shop_container.list .product_img {
    float: left;
    width: 100%;
    max-width: 280px;
}
@media only screen and (max-width: 767px) {
    .shop_container.list .product_img {
        float: left;
        width: 100%;
        max-width: 50%;
    }
    
}
@media only screen and (max-width: 480px) {
    .shop_container.grid .col-6 {
        max-width: 50%;
        -ms-flex: 0 0 50%;
        margin: 0;
    }
    .shop_container.grid .col-6:nth-child(2n+1) {
      margin-left: 0px;
    }
    .shop_container.grid .col-6:nth-child(2n) {
      margin-left: 0px;
    }
}
.header_wrap.fixed-top {
    position: sticky;
}
.nav-tabs .nav-item {
  margin-bottom: -1px;
  width: 30%;
  display: inline-block;
}
.row.align-items-center.mb-4.pb-1 div.col {
  margin-bottom: 10px;
}
.buy_container {
    position: sticky;
    bottom: 0px;
    z-index: 20;
    padding: 6px 0;
    background: #fff;
    -webkit-box-shadow: rgb(0 0 0 / 50%) 0px -6px 6px -6px;
    -moz-box-shadow: rgb(0 0 0 / 50%) 0px -6px 6px -6px;
    box-shadow: rgb(0 0 0 / 50%) 0px -6px 6px -6px;
}

.shop_container .button-detail,
#product_card .button-detail {
    font-size: 12px;
    color: #000;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
    width: 85%;
    margin: 0 auto;
}

.shop_container a.disable,
.shop_container button.disable,
#product_card button.disable,
#goToPay.disable,
#sign-up.disable {
    color: #fff;
    cursor: not-allowed;
    border-radius: 15px;
    text-decoration: none;
    background-color: #858585;
    border: 1px solid #858585;
}
.shop_container a:hover.disable,
.shop_container button:hover.disable,
#product_card button:hover.disable,
#goToPay:hover.disable,
#sign-up:hover.disable {
    opacity: 1;
}
.member-center-item.disable {
    color: #dbdbdb;
    cursor: not-allowed;
    text-decoration: none;
}
select option.disable {
    background: #dbdbdb;
    color:#fff;
}
.limited_warning {
  background: #c20000;
  font-weight: 600;
  text-align: center;
  font-size: 16px;
  color: #fff;
  border-radius: 5px;
  margin-top: 5px;
  margin-bottom: 5px;
}
.btn.disabled, .btn:disabled {
  cursor: not-allowed;
  text-decoration: none;
}
.table.table-list a,
.shopping-table.table-list a {
  color: #FF324D;
}
.help-block.with-errors {
  color: #ed1c24;
}
.pickup-store {
  display: none;
}
.pickup-store.active {
  display: block;
  margin-bottom: 30px;
}
@media only screen and (max-width: 480px) {
  .table.table-list td:first-child {
      width: 24% !important;
      font-size: 12px;
  }
  .table.table-list td:nth-child(2) {
      width: 40%;
  }
  .table.table-list td, .table.table-list th {
    padding: .5rem;
  }
  .shopping-table.table-list td:first-child {
    width: 60% !important;
    font-size: 12px;
  }
  .shopping-table.table-list td:nth-child(2) {
      width: 25%;
  }
  .shopping-table.table-list td, .shopping-table.table-list th {
    padding: .5rem;
  }
}
@media only screen and (max-width: 575px) {
  .breadcrumb_section.page-title-mini {
      padding: 10px 0;
  }
  .breadcrumb_section.pd_0 {
    padding: 0;
  }
}
.product_img:before {
  display: none;
}
.on_sale {
  display: inline-block;
  color: #388e3c;
  font-size: 18px;
}
.price {
  color: #FF324D;
  font-weight: 600;
  vertical-align: bottom;
  font-size: 26px;
  line-height: 34px;
  display: inline;
  bottom: 20px;
}
.grid .product_info {
  min-height: 180px;
  margin-bottom: 15px;
}
.grid .product_info.category {
  height: 78px;
}
.product_price del {
  vertical-align: bottom;
  line-height: 25px;
}
.carousel-indicators {
  bottom: 0;
}
.carousel-indicators li {
  background: #333;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border-top: 0;
  border-bottom: 0;
  opacity: .3 !important;
}
.carousel-indicators .active {
  opacity: .7 !important;
}

.shop_container.list .product .product_title, 
.shop_container.grid .product .product_title {
  font-family: "MicrosoftJhengHeiUI", "\5FAE\8EDF\6B63\9ED1\9AD4", "Microsoft JhengHei" !important;
  margin-bottom: 10px;
  
  white-space: normal;
  display: -webkit-box;
  max-width: 100%;
  height: 48px;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.5;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
img {
  max-width: 100%;
  width: 100%;
}
img.lazy {
  /* background-image: url('../images/ajax-loader.gif'); */
  background-repeat: no-repeat;
  background-position: 50% 50%;
}
.main-banners .col-6 {
  padding-right: 0;
  padding-left: 0;
}
@media only screen and (max-width: 575px) {

  .align-items-center .col-6:nth-child(2) {
    text-align: right;
  }
  .header_wrap.fixed-top {
    position: fixed;
  }
}
.btn-grey-out {
  background-color: transparent;
  border: 1px solid #858585;
  color: #fff;
  position: relative;
  overflow: hidden;
  z-index: 1;
  border-radius: 15px;
}
.btn-grey-out::before, .btn-grey-out::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background-color: #858585;
  z-index: -1;
  transition: all 0.3s ease-in-out;
  width: 51%;
}
.btn-grey-out::after {
  right: 0;
  left: auto;
}
.btn-blue-out {
  background-color: transparent;
  border: 1px solid #2196F3;
  color: #fff;
  position: relative;
  overflow: hidden;
  z-index: 1;
  border-radius: 15px;
}
.btn-blue-out::before, .btn-blue-out::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background-color: #2196F3;
  z-index: -1;
  transition: all 0.3s ease-in-out;
  width: 51%;
}
.btn-blue-out::after {
  right: 0;
  left: auto;
}
.warning-message {
  display: none;
  color: #FF324D;
}
.warning-message.show {
  display: inline-block;
}
.col-12.text-center img.barcode{
  max-width: 90%;
  width: 90%;
}
/* cookie存取 */
body.overage { 
  background: #a6ddc3;
}
body.underage { }
.age-box a.btn{
  color: #fff;
  text-decoration: none;
  display:inline-block;
  letter-spacing: 0.1em;
  padding: 0.5em 0em;
}

.overlay-verify {
  background: #000;
  position:fixed;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 1;
}
.overage .overlay-verify {
  display: none;
}
.overage .age-box {
  display: none;
}
.age-box{
  background: #fff;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: 0 auto;
  z-index: 9;
  width: 100vw;
  height: 100vh;
  display:table;
}
.age-box-right{
  width: 100%;
  position: relative;
  text-align: center;
  padding: 5%;
  padding-top: 25vh;
  text-align: center;
}
.age-box p {
  padding: 5%;
  position: relative;
  z-index: 3;
} 
.age-box p.decor-line {
	position:	relative;
	top:	0.7em;
  border-top: 1px solid #ccc;
  text-align:center;
  max-width: 40%;
  margin: 0.5em auto;
  display: block;
  padding: 0.1em 1em;
  color: #ccc;
}
.age-box .decor-line span{
    background: #fff;
    color: #ccc;
    position: relative;
    top: -.7em;
    padding: 0.5em;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight:	900;
  }
.age-box h3 {
  color: #555;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border-bottom: 1px solid #eee;
  padding-bottom: 1em;
  margin: 0 auto;
}
.age-box .btn{
  font-weight: 600;
  letter-spacing: 0.2em;
  padding: 0.9em 1em 0.7em;
  margin: 1em auto;
  display: block;
}
.age-box .btn-alpha {
  font-size: 16px;
  width: auto;
  height: auto;
  padding: 12px 30px;
  background-color: #c20000;
  border: 1px solid #c20000;
  color: #fff;
  border-radius: 4px;
}
.age-box .btn-beta {
  font-size: 16px;
  width: auto;
  height: auto;
  padding: 12px 30px;
  background-color: #858585;
  border: 1px solid #858585;
  color: #fff;
  border-radius: 4px;
}

.customize-close {
    float: right;
    line-height: 1;
    text-shadow: 0 1px 0 #fff;
    padding: 0;
}

.shopping-cart,
.order-complete {
    padding-bottom: 280px;
    margin-bottom: 30px;
}

@media only screen and (max-width: 450px) {
    .shopping-cart,
    .order-complete {
        padding-bottom: 200px;
    }
}

.divider-color {
  position: relative;
  overflow: hidden;
  height: 4px;
  z-index: 9;
}
.divider-color:before {
  content: '';
  position: absolute;
  width: 100%;
  top: 50%;
  left: 0px;
  height: 0;
  border-top: 1px solid #c20000;
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.divider-color:before {
  margin-top: -1px;
}
.cart-title {
  height: 30px;
  font-size: 18px;
  line-height: 30px;
  background: #D38598;
  color: #FFF;
  margin-bottom: 10px;
}
.cart-item .item-body {
  padding: 10px 5px 0 10px;
  margin: 10px 0;
  border-radius: 10px;
  background: #fbfbfb;
}
.cart-bg {
  padding: 10px 0;
  margin: 0 0 10px 0;
  border-radius: 10px;
  background: #fbfbfb;
}
.cart-item .item-body.expire img, 
.cart-item .item-body.expire .cart-item-name,
.cart-item .item-body.expire .price {
  opacity: 0.4;
}
.cart-item-name {
  text-overflow: ellipsis;
  overflow: hidden;
  height: 44px;
}
.cart-item .item-body.price {
  font-size: 20px;
}

.cart-mark {
  background: #7c7c7c;
  color: #fff;
  padding: 0 5px;
}
.quantity .minus.disabled, .quantity .plus.disabled {
  opacity: 0.3;
}
.quantity .qty {
  height: 30px;
}
.shopping-cart-list .col-5,
.shopping-cart-list .col-7 {
  margin: 4px 0;
}
.shopping-number {
  letter-spacing: 2px;
  padding: 5px;
  background: #717171;
  color: #fff;
  border-radius: 3px;
}
.highlight-border {
  color: #FF324D;
  border-radius: 3px;
  padding: 2px;
  border: 1px solid #FF324D;
}
.shopping-cart-footer {
  position: fixed;
  bottom: 0;
  width: 100%;
  margin: 0;
  background: #fff;
  z-index: 10;
  padding: 10px 0;
}
.mark-note {
  display: none;
  color: #c20000;
  margin-right: 5px;
  width: fit-content;
  float: right;
}
.mark-note.show {
  display: block;
}
.remove-cart {
  line-height: 38px;
}
.remove-cart i {
  margin-right: 5px;
}
.totalamout-block {
  position: fixed;
  bottom: 0;
  background: #fff;
  padding: 10px 0;
  z-index: 10;
}
.custome-radio.disable {
  opacity: 1;
}
.cart-price-cell {
  vertical-align: middle;
  font-weight: 700;
  margin-right: 15px;
  float: right;
}
.method-block, 
.point-block {
  height: 0;
  padding: 0;
  transition: max-height 0.3s ease-out;
  transition: padding 0.1s ease-out;
  overflow: hidden;
  color: #383838;  
}
.method-block.open,
.point-block.open {
  height: 100%;
  padding: 10px 0;
  transition: padding 0.1s ease-out;
  transition: 0.3s ease-in;
  color: #383838;
  border-radius: 10px;
}
.credit-block {
  display: none;
  padding: 0 0 10px 0;
  color: #383838;
  border-radius: 10px;
}
.credit-block.open {
  display: block;
}
.shopping-cart-icon {
    width: 40px;
}
.cart-qty {
  height: 19px;
  width: 19px;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
  color: #fff;
  background: #D38598;
  border-radius: 50% 50%;
  border: 1px solid #fff;
  text-align: center;
  margin-left: -18px;
  margin-top: 15px;
  display: inline-block;
  vertical-align: top;
}
.limited-bank {
  color: #ed1c24;
  float: right;
  margin-bottom: 10px;
}
#bankModal .modal-dialog{
  top: 35%;
}
/* #warningModal .modal-footer a {
  color: #fff;
}
#warningModal .modal-footer .btn {
  width: 47%;
  display: inline-block;
} */
.notice-text {
    color: #ed1c24;
    text-align: right;
    font-weight: 500;
    font-size: 13px;
    margin-left: 10px;
}

.normal-text {
    text-align: right;
    font-weight: 500;
    font-size: 13px;
    margin-left: 10px;
}
/*購物車 信用卡選單*/
.vodiapicker{
  display: none; 
}
#ulList{
  padding-left: 0px;
}
#ulList img, .btn-select img{
  width: 40px;
}
#ulList li{
  list-style: none;
  height: 64px;
  line-height: 30px;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #e2e2e2;
  align-items: center;
}
#ulList li:hover{
 background-color: #F4F3F3;
}
#ulList li img{
  margin-right: 10px;
}
#ulList li span {
  margin-left: 10px;
  margin-right:10px;
}
#ulList li span.number {
  margin-left: 10px;
  width: 65%;
  display: inline-block;
}
.btn-select li span.number {
  margin-left: 10px;
  width: 75%;
  display: inline-block;
  line-height: 26px;
  vertical-align: sub;
}
.listContainer{
  display: none;
  width: 100%;
  max-width: 350px;
  box-shadow: 0 6px 12px rgba(0,0,0,.175);
  border: 1px solid rgba(0,0,0,.15);
  border-radius: 5px;
  position: absolute;
  top: 74px;
  background: #fff;
  z-index: 999;
}
.btn-select{
  margin-top: 10px;
  width: 100%;
  max-width: 350px;
  height: 64px;
  border-radius: 5px;
  background-color: #fff;
  border: 1px solid #ccc;
}
.btn-select li{
  list-style: none;
  padding-bottom: 0px;
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
}
.btn-select:hover li{
  margin-left: 0px;
}
.btn-select:hover{
  background-color: #F4F3F3;
  border: 1px solid transparent;
  box-shadow: inset 0 0px 0px 1px #ccc;
}
.btn-select:focus{
   outline:none;
}
.list-select{
  position: relative;
}
.list-select.custom_select::before {
  top: 60%;
}
i.fa-trash-alt {
  z-index: 999;
}
.modal-open #alert_lightbox.modal {
    display: flex !important;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}

.modal-open #mBarCodeModal.modal {
    display: flex !important;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}

#alert_lightbox.modal.show .modal-dialog {
    max-width: 320px;
    width: 320px;
}

.modal-open #alert_lightbox.modal.hide {
    display: none !important;
}

.modal-open #warningModal.modal.show {
    display: flex !important;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}

select[readonly] {
    pointer-events: none;
}

.banner-img-rounded {
    border-radius: 12px;
}
.product {
    min-width:150px;
}

.product_info .product_tag {
    text-align: center;
    margin: 8px 0;
    height: 26px;
}

.product_info .product_price > div:not(:last-child) {
    height: 26px;
}
.product_info .product_price > div:last-child {
    height: 50px;
}

.product_info .product_tag span {
    border: 1px solid #dc3848;
    padding: 2px 10px 2px 10px;
    border-radius: 5px;
    margin: 0px 12px 0px 12px;
}

.pr_detail .product_tag {
    margin: 12px 0;
}

.pr_detail .product_tag span {
    border: 1px solid #dc3848;
    padding: 2px 10px 2px 10px;
    border-radius: 5px;
    margin: 0px 12px 0px 0px;
}

.btn-add-cart {
    background: #D38598;
    color: #fff;
    border-radius: 15px;
    padding: 5px 0;
}

.btn-buy {
    background: #5D90F5;
    color: #fff;
    border-radius: 15px;
    padding: 5px 0;
}
.btn-point-buy {
    background: #ffa000;
    color: #fff;
    border-radius: 15px;
    padding: 5px;
}
.product-button .btn-add-cart {
    font-size: .9rem;
}

/* 加入購物車按鈕按下時的顏色變更 */
.btn-add-cart:active {
    background-color: #B36B7E; /* 較深的粉紅色 */
    transition: background-color 0.5s ease;
}

/* 立即購買按鈕按下時的顏色變更 */
.btn-buy:active {
    background-color: #4A73C4; /* 較深的藍色 */
    transition: background-color 0.5s ease;
}


.product-button .btn-buy {
    font-size: .9rem;
}

.product-button {
    height:23px;
    text-align: center;
}
.btn-search-type.active {
    background: #D38598;
    color: #fff;
    border-radius: 15px;
}
.btn-search-type.inactive {
    background: #FFF;
    color: #D38598;
    border-radius: 15px;
}
.btn-search-type {
    font-size: 1.1rem;
    padding: 10px 20px;
    margin: 0px 8px 0px 8px;
    border: 1px solid #D38598;
}
/* modal-bottom start*/
.modal.modal-bottom .modal-dialog {
    -webkit-transform: translate3d(0%, 0, 0);
    -ms-transform: translate3d(0%, 0, 0);
    -o-transform: translate3d(0%, 0, 0);
    transform: translate3d(0%, 0, 0);
}

.modal.modal-bottom .modal-content {
    border-radius: 0;
    border: none;
}

.modal.modal-bottom .modal-dialog {
    position: fixed;
    margin: auto;
    width: 100%;
    max-width: 100%;
    height: auto;
}

.modal.modal-bottom .modal-content {
    height: auto;
    overflow-y: auto;
}

.modal.modal-bottom .modal-body {
    padding: 0px 6px 4px 6px;
}

.modal.modal-bottom.fade .modal-dialog {
    bottom: -100%;
    -webkit-transition: opacity 0.1s linear, bottom 0.1s ease-out;
    -moz-transition: opacity 0.1s linear, bottom 0.1s ease-out;
    -o-transition: opacity 0.1s linear, bottom 0.1s ease-out;
    transition: opacity 0.1s linear, bottom 0.1s ease-out;
}

.modal.modal-bottom.fade.show .modal-dialog {
    bottom: 0;
}

.modal.modal-bottom.fade .modal-dialog {
    bottom: -100%;
}

/* modal-bottom end*/

.footer_content ul {
    list-style: none;
}
.footer_content ul.about_list li+li::before {
    padding: 5px;
    color: black;
    content: "\007C";
}
.footer_content ul.share li {
    padding: 10px;
    color: black;
    content: "";
}
.ui-slider .ui-slider-handle {
    width: 1.5em !important;
    height: 1.5em !important;
}

.ui-slider-horizontal .ui-slider-handle {
    top: -0.7em !important;
}

.ui-state-default, .ui-widget-content .ui-state-default {
    background: #fff !important;
    border-radius: 15px !important;
}

.ui-widget-header {
    background: #5D90F5 !important;
}

.ui-slider-horizontal {
    height: 0.4em !important;
}

.addloadanimate {
    background-color: #fff;
}

.placeholder {
    color: transparent;
    background-color: #fff;
    background: linear-gradient( 100deg, rgba(256, 256, 256, 0) 30%, rgba(256, 256, 256, 0.5) 50%, rgba(256, 256, 256, 0) 30%) #ededed;
    background-size: 200% 100%;
    background-position-x: 180%;
    animation: 1s skeleton ease-in-out infinite;
}

.placeholder *,
.addloadanimate *{
    opacity: 0;
}
.placeholder i,
.addloadanimate i{
    display: none;
}

.placeholder a,
.addloadanimate a{
    font-size: 0;
}

@keyframes skeleton {
    to {
        background-position-x: -20%;
    }
}


body.loaded .placeholder {
    color: unset;
    animation: none;
    background: none !important;
}
body.loaded .placeholder * {
    opacity: 1;
    transition: opacity .3s;
}
body.loaded .placeholder i {
    display: unset;
}
body.loaded .placeholder a {
    font-size: inherit;
}

@media only screen and (min-width: 1200px) {
    .productlist_section {
        max-width: 1140px;
        width: 100%;
        padding-right: 15px;
        padding-left: 15px;
        margin-right: auto;
        margin-left: auto;
    }
    .product_img img {
        width: 500px !important;
    }
}

@media only screen and (max-width: 365px) {
    .home_productlist_section {
        min-width: 320px;
        overflow: auto;
    }
    .productlist_section {
        min-width: 320px;
        overflow: auto;
    }
    .product_info .product_tag span {
        margin: 0 6px 0 6px;
    }
}

div[data-detailurl] {
    cursor: pointer;
}

.swiper-pagination-bullet {
    background-color: #D38598;
    transition: 0.5s;
}

.swiper-pagination-bullet-active {
    padding: 0 8px;
    border-radius: 6px;
    transition: 0.5s;
}

.modal-body p a {
    overflow-wrap: break-word;
}