label {
    font-weight: normal;
    color: var(--p-font-color);
    margin-bottom: 5px;
    cursor: pointer;
    position: relative;
    display: flex;
}

select {
    min-height: inherit !important;
}

input, select, .form-control, select.form-control:not([size]):not([multiple]) {
    background-color: var(--gray-100) !important;
    outline: 0;
    font-weight: normal;
    line-height: 1.4;
    border-radius: 8px;
    width: 100%;
    border: 1px solid var(--gray-100);
    height: 48px;
    color: var(--p-font-color);
    padding: 12px;
}

.form-select {
    border: 1px solid var(--gray-100);
}

input:hover, select:hover, .form-control:hover, select.form-control:not([size]):not([multiple]):hover {
    border: 1px solid var(--gray-900);
    background-color: #fff !important;
}

.form-control:disabled, .form-control[readonly] {
    background-color: #f3f3f3 !important;
    color: var(--gray-600);
    border: 1px solid transparent;
}

.form-control.flatpickr:disabled, .form-control.flatpickr[readonly] {
    color: var(--gray-900);
}

textarea {
    min-height: 100px;
    width: 100%;
    outline: 0;
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder,
.form-control::-webkit-input-placeholder {
    font-weight: 300;
    color: var(--gray-300);
    opacity: 0.6;
}

input::-moz-placeholder,
textarea::-moz-placeholder,
.form-control::-moz-placeholder {
    font-weight: 300;
    color: var(--gray-300);
    opacity: 0.6;
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder,
.form-control:-ms-input-placeholder {
    font-weight: 300;
    color: var(--gray-300);
    opacity: 0.6;
}

input::-ms-input-placeholder,
textarea::-ms-input-placeholder,
.form-control::-ms-input-placeholder {
    font-weight: 300;
    color: var(--gray-300);
    opacity: 0.6;
}

input::placeholder,
textarea::placeholder,
.form-control::placeholder {
    font-weight: 300;
    color: #6c757d;
    opacity: 0.6;
}

.form-control:focus, input:focus, select:focus, textarea:focus, select.form-control:not([size]):not([multiple]):focus {
    border-color: var(--p-main-color) !important;
}

select, select.form-control:not([size]):not([multiple]) {
    background-color: var(--gray-100);
    padding-left: 8px;
}

.form-control:focus, input:focus {
    background-color: transparent;
    box-shadow: none;
}

textarea.form-control {
    min-height: 100px;
}

table+table {
    margin-top: 20px;
}

.col-form-label small {
    color: var(--p-focus-color);
    padding-right: 3px;
}

input[type="radio"], input[type="checkbox"] {
    margin: 8px 5px 0 5px;
    width: 15px;
    height: 15px;
}

.color1 {
    color: var(--p-main-color);
}

.col-sm-9.color1, .col-9.color1 {
    padding-top: calc(0.375rem + 1px);
    padding-bottom: calc(0.375rem + 1px);
    min-height: 48px;
    align-items: center;
    display: inline-flex;
    gap: 0.25rem;
}

/* .input-group .form-control {
    border-radius: 0;
    height: 46px;
    box-shadow: none;
}

.input-group .input-group-btn>.btn, .input-group .input-group-addon {
    border-radius: 0;
    margin-bottom: 5px;
    background: var(--p-main-color) !important;
} */

.red {
    color: var(--p-focus-color) !important;
}

.main-color {
    color: var(--p-main-color) !important;
}

/*************member & shoppingcart*****************/
.full-page {
    padding: 3rem 0 5rem 0;
    margin: auto;
    float: none;
    overflow: hidden;
    min-height: calc(100dvh - 150px);
}

@media(max-width:767px) {
    .full-page {
        padding: 1rem 0;
        min-height: calc(100dvh - 140px);
    }
}

.full-page h1 {
    font-size: 32px;
}

.input-block-level {
    display: block;
    width: 100%;
    min-height: 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.form-container {
    font-size: 16px;
    padding: 50px;
    background-color: var(--gray-100);
    margin: auto;
}

.form-container p, .notice-info {
    font-size: 16px;
    margin-top: 0.25rem;
}

.form-container form {
    clear: both;
}

.form-container .form-group {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    margin-bottom: 15px;
}

.form-container .form-group.top-line {
    border-top: 1px solid var(--gray-300);
    margin-top: 30px;
    padding-top: 30px;
}

@media (min-width: 576px) {
    .form-container .form-inline .form-check {
        margin: 12px 0;
    }
}

.text-error, label.error {
    display: block;
    clear: both;
    color: var(--p-focus-color) !important;
    margin-top: 4px;
    font-size: 14px;
}

.input-group-btn {
    overflow: hidden;
    margin-bottom: 4px;
    display: inline-table;
}

.form-container.form-complete .form-group {
    line-height: 200%;
    min-height: 40px;
}

.form-container .control-txt {
    padding: 10px 15px;
    font-size: 16px;
}

.checkout-page .form-actions {
    text-align: center;
}

.checkout-page .form-actions input[type=checkbox].ace.input-lg+.lbl::before {
    top: -4px;
}

.checkout-page .form-actions.align-right {
    text-align: right;
}

.checkout-page .form-actions .order-btn {
    width: 220px;
    background-color: transparent;
    border: 1px solid #000;
    color: var(--gray-900) !important;
}

.checkout-page .form-actions .order-btn.buy-now {
    color: #fff !important;
}

.checkout-page .form-actions .order-btn.btn-sm {
    width: 120px;
    min-width: fit-content;
    padding: 7px 15px;
    font-size: 14px;
    height: 40px;
}

.form-actions label {
    display: block;
    margin-bottom: 1rem;
}

.form-container .help-inline {
    float: none;
}

.form-container .button-s, form .button-s {
    height: 30px;
    line-height: 30px;
    padding: 0 20px;
}

.form-container #verifycodeImg {
    height: 45px;
    margin-right: 10px;
}

.middle i {
    font-size: 18px;
    margin-top: 8px;
}

.form-container .form-group.txt {
    margin-bottom: 20px;
    text-align: center;
    font-size: 15px;
}

.form-block.product_details .product-review-tab {
    margin-bottom: 0;
    margin-top: 0;
}

/* .form-block.product_details .product-review-tab .nav{
    display: block;
    width: 100%;
} */
.form-block.product_details .product-review-tab .nav li {
    margin-bottom: -1px;
    width: auto;
}

.form-block.product_details .product-review-tab .nav li a {
    color: var(--p-font-color);
    border: 0;
    background-color: transparent;
    font-size: 16px;
    padding: 15px 35px;
    display: block;
    border: 1px solid transparent !important;
    border-radius: 6px 6px 0 0;
}

.form-block.product_details .product-review-tab .nav li a.active {
    background: var(--gray-100);
    border-bottom: 0;
}

.form-block.product_details .product-review-tab .nav li.active a::after {
    display: none;
}

.form-block.product_details .product-review-tab .nav {
    border-bottom: 0;
}

.form-block.product_details .tab-content {
    margin-top: -1px;
    padding: 30px;
    background-color: var(--gray-100);
    width: 100%;
    margin-bottom: 0;
}

.form-block.product_details .tab-content input,
.payment-select1 .form-block input,
.payment-select1 .form-block .form-control {
    background-color: #fff !important;
}

.input-group-btn .btn {
    font-size: 14px;
    border: 0;
    border-radius: 0;
    margin-right: 4px;
}

.success {
    background-color: #f4f4f4;
    text-align: center;
    font-size: 110%;
    border-radius: 5px;
}

.success .title {
    font-size: 130%;
    font-weight: bold;
}

.success p {
    margin: 20px 0;
}

.steps {
    list-style: none;
    display: flex;
    width: 80%;
    padding: 0;
    margin: auto;
    margin-bottom: 30px;
    position: relative;
}

.steps li {
    text-align: center;
    flex: 1;
}

.steps li .step {
    border: 5px solid var(--gray-300);
    color: var(--gray-900);
    font-size: 13px;
    border-radius: 100%;
    background-color: #FFF;
    position: relative;
    z-index: 1;
    display: inline-block;
    width: 60px;
    height: 60px;
    line-height: 50px;
    text-align: center;
}

.steps li.active .step, .steps li.active:before {
    border-color: var(--gray-800);
    color: var(--gray-900);
}


.steps li:before {
    display: block;
    content: "";
    width: 100%;
    height: 1px;
    font-size: 0;
    overflow: hidden;
    border-top: 4px solid var(--gray-300);
    position: relative;
    top: 31px;
    z-index: 1;
}

.steps li.last-child:before {
    max-width: 50%;
    width: 50%;
}

.steps li:last-child:before {
    max-width: 50%;
    width: 50%;
}

.steps li:first-child:before {
    max-width: 51%;
    left: 50%;
}

.steps li.complete .step {
    cursor: default;
    color: #FFF;
    -webkit-transition: transform ease 0.1s;
    -o-transition: transform ease 0.1s;
    transition: transform ease 0.1s;
}

.steps li.complete .step:before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    line-height: 30px;
    text-align: center;
    border-radius: 100%;
    content: "\f00c";
    background-color: #FFF;
    z-index: 3;
    font-family: FontAwesome;
    font-size: 16px;
    color: #87ba21;
}

.steps li.complete:hover .step {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -o-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
    border-color: #80afd4;
}

.steps li.complete:hover:before {
    border-color: #80afd4;
}

.steps li .title {
    display: block;
    margin: 5px 0;
    max-width: 100%;
    color: var(--p-font-color);
    font-size: 13px;
    letter-spacing: 0;
}

.steps li.active .title {
    color: var(--p-font-color);
}


.step-content {
    position: relative;
}

.step-content .step-pane {
    display: none;
    min-height: 200px;
    padding: 4px 8px 12px;
}

.step-content .step-pane.active {
    display: block;
}


@media (max-width: 575px) {
    .steps li .title {
        font-size: 13px;
        font-weight: 300;
    }
}

.full-page .title {
    font-size: 36px;
    letter-spacing: 2px;
    color: var(--p-font-color);
    font-weight: 400;
    margin-bottom: 1rem;
}

.center {
    text-align: center;
}

.cart-tabs .nav-pills {
    display: flex;
    align-items: center;
    border-bottom: 0px solid var(--p-main-color);
}

@media(min-width: 767.88px) {
    .cart-tabs .nav-pills {
        display: none;
    }
}

.cart-tabs .nav-pills li {
    flex: 1;
    /* max-width: 200px; */
}

.cart-tabs .nav-pills li+li {
    margin-left: 10px;
}

.cart-tabs .nav-pills .nav-link {
    width: 200px;
    width: 100%;
    padding: 12px 10px 8px;
    font-size: 17px;
    font-weight: 400;
    background: var(--gray-300);
    color: var(--gray-900);
    text-align: center;
    /* align-items: center; */
    border-radius: 0;
    position: relative;
    cursor: pointer;
}

.cart-tabs .nav-pills .nav-link.active {
    background-color: var(--gray-300);
    color: var(--gray-900);
}

.cart-tabs .nav-pills .nav-link span {
    font-size: 15px;
    font-weight: bold;
    min-width: 22px;
    height: 22px;
    line-height: 22px;
    display: inline-flex;
    padding: 0 5px;
    margin-left: 0.25rem;
    background-color: var(--gray-400);
    color: var(--gray-900);
    display: none;
}

.shop_table {
    border: 1px solid var(--gray-300);
    width: 100%
}

.shop_table>tbody>tr>td, .shop_table>tbody>tr>th, .shop_table>tfoot>tr>td, .shop_table>tfoot>tr>th, .shop_table>thead>tr>th {
    padding: 10px;
    border-top: 1px solid var(--gray-300)
}

.shop_table>tfoot, .shop_table>thead {
    background-color: #f3f2eb
}

.payment .payment_methods {
    list-style: none;
    margin: 10px 0;
    padding: 10px;
    border: 1px solid var(--gray-300);
    border-radius: 2px;
    background-color: #f3f2eb
}

.payment .payment_box {
    margin: 10px 1.5%;
    padding: 10px 10px 0;
    border: 1px solid var(--gray-300);
    border-radius: 2px;
    background-color: var(--gray-300);
    display: none
}

.shop-cart-table {
    width: 100%;
}

.shop-cart-table th {
    padding: 10px;
    text-align: center;
    font-weight: 400;
    white-space: nowrap;
}

.shop-cart-table td {
    line-height: 1.4;
    color: var(--p-font-color);
    padding: 20px 10px;
    border-bottom: 1px solid var(--gray-300);
    text-align: center;
    vertical-align: middle;
}

.no-item td {
    padding: 50px 0 !important;
}

/* .shop-cart-table .cart_table_title {
    color: var(--p-font-color);
    border-bottom: 1px solid var(--gray-300);
    font-size: 15px;
} */
.shop-cart-table .cart_table_title {
    color: var(--gray-100);
    font-size: 15px;
    background-color: var(--gray-800);
}

.shop-cart-table .cart_table_title .actions {
    width: 100%
}

.shop-cart-table .quantity {
    margin: 0
}

.shop-cart-table .quantity {
    width: 120px;
}

.shop-cart-table .quantity input[type="number"] {
    font-size: 16px;
    text-align: center;
    padding: 0 40px;
    height: 40px;
}

.shop-cart-table .quantity span {
    width: 40px;
    height: 40px;
}

.shop-cart-table .quantity span i {
    font-size: 18px;
}

.shop-cart-table tr.gry,
.shop-cart-table tr.gry td {
    background-color: var(--gray-100);
}

.shop-cart-table tr.gry td.product-subtotal:before {
    display: none;
}

.shop-cart-table .product-remove {
    width: 5%;
}

.shop-cart-table .product-remove a {
    color: #000;
    font-size: 21px;
    opacity: 0.5;
}

.shop-cart-table .product-remove a:hover {
    opacity: 1;
}

.shop-cart-table .product-remove .fa-times:before,
.campaign-title i.fa-times:before,
a.remove i.fa-times:before,
.shop-cart .shop-cart__list .item .remove:before,
.file-upload .item .fa-times:before {
    content: "\e9e4";
    font-family: 'Feather';
}

.shop-cart-table .product-thumbnail {
    width: 7%;
    padding: 20px 10px;
}

.shop-cart-table .product-thumbnail img {
    border: 1px solid #f1f1f1;
}

.product-name,
.shop-cart-table .product-name {
    text-align: left;
}

.form-block .shop-cart-table {
    margin-bottom: 1rem;
    border: 1px solid var(--gray-300);
}

.form-block .shop-cart-table td {
    border-bottom: 1px solid var(--gray-300);
}

.shop-cart-table td .pro-item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}

.item-thumbs {
    width: 70px;
    margin-right: 12px;
    border: 1px solid #efefef;
}

.item-info {
    flex: 1;
}

.item-info .price, .item-info .qty {
    display: none;
    margin-top: 4px;
}

.item-info .amount {
    padding: 2px 5px;
    background-color: var(--gray-400);
    color: #fff;
    display: inline-block;
    line-height: 1;
    margin-left: 5px;
    border-radius: 4px;
}

.item-info .increase {
    display: flex;
    width: fit-content;
    color: #fff;
    padding: 2px 8px;
    font-size: 13px;
    line-height: 1.5;
    font-weight: 300;
    position: relative;
    border-radius: 4px;
    background-color: var(--p-main-color);
    align-items: center;
    justify-content: center;
}

.item-info .increase.free {
    background-color: #ff96ad;
}

.item-info .increase.normal {
    background-color: #77d637;
}

.item-info .increase.low {
    background-color: #5fcfff;
}


.item-info .increase.color1.flex-column {
    background-color: #7ce1e8;
}

ta-table .increase.cool::after {
    border-right-color: #7ce1e8;
}

td.product-name .spec, .item-info .spec {
    color: var(--gray-600);
    width: auto;
    display: block;
    margin-top: 4px;
}

td.product-name .spec small, .item-info .spec small {
    margin: 0 2px;
    color: #ddd;
}

.item-info .spec.group-buy {
    background-color: var(--gray-100);
    padding: 0.75rem;
    color: var(--gray-900);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin: 0.5rem 0;
}

.item-info .spec.group-buy ul {
    padding: 0;
    list-style-type: none;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin: 0;
}

.item-info .spec.group-buy ul span {
    display: block;
}

.shop-cart-table td.product-name .note {
    color: #f76686;
    display: block;
    font-size: 14px;
}

.shop-cart-table td.product-name .note strong {
    font-weight: 500;
}

.shop-cart-table .product-name .price {
    font-size: 16px;
}

.shop-cart-table .product-name .price-old {
    margin-right: 5px;
    float: none;
}

.shop-cart-table .event {
    font-size: 14px;
    color: var(--gray-600);
    margin-top: 0.25rem;
}

.shop-cart-table .event::before,
.discount-list span.thumb::before {
    font-family: "FontAwesome";
    margin-right: 3px;
}

.shop-cart-table .event.yes::before,
.discount-list.yes span.thumb::before {
    content: "\f00c";
}

.shop-cart-table .event.no::before,
.discount-list.no span.thumb::before {
    content: "\f00d";
}

.shop-cart-table .event.no {
    color: var(--p-focus-color);
}

.shop-cart-table .product-price {
    width: 10%
}

.shop-cart-table .price-old {
    display: block;
    float: none;
    margin-left: 0;
}

.price-old {
    font-weight: 300;
    text-decoration: line-through;
    margin-left: 5px;
    font-size: 14px;
    line-height: 1.4;
    color: var(--gray-400);
}

.shop-cart-table small {
    font-size: 100%;
}

.shop-cart-table .product-quantity {
    width: 15%;
    float: none;
}

.shop-cart-table input#product-quantity {
    display: table-cell;
    border: 1px solid #ddd;
    height: 40px;
    width: 40px;
    line-height: 40px;
    font-weight: normal;
    font-size: 16px;
}

.shop-cart-table .btn-input-group {
    display: table-cell;
    width: 25px;
}

.shop-cart-table span#product-quantity-plus {
    border-bottom: 0;
}

.shop-cart-table span#product-quantity-plus,
.shop-cart-table span#product-quantity-minus {
    width: 20px;
    height: 20px;
    line-height: 20px;
}

.shop-cart-table .product-quantity .qty-set {
    display: table;
    margin: auto;
}

.shop-cart-table .product-quantity input[type="text"] {
    margin-bottom: 0;
}

.shop-cart-table .product-subtotal {
    width: 10%
}

.shop-cart-table .cart_table_action {
    background-color: #f3f2eb
}

.shop-cart-table .cart_table_action .actions {
    padding: 8px 0
}

.shop-cart-table .cart_table_action .actions .btn {
    margin-left: 10px
}

.shop-cart-table .cart_table_action .input-text {
    width: 120px;
    display: inline-block;
    height: 36px;
    background-color: #fff
}

.display-phone {
    display: none !important;
}

.total-block {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-top: 1rem;
}

.total-block.cart {
    justify-content: flex-end;
}

.total {
    font-size: 14px;
    color: var(--p-font-color);
    clear: both;
    margin-bottom: 20px;
    display: flex;
    justify-content: flex-end;
}

.total th {
    font-weight: 400;
}

.total th, .shopping-cart .total td {
    text-align: right;
    background-color: transparent;
    padding: 5px 10px;
    border: 0;
}

.total th {
    display: inline-flex;
    width: 100%;
    align-items: flex-start;
    justify-content: flex-end;
}

.total td {
    width: 90px;
    font-size: 16px;
    white-space: nowrap;
    text-align: right;
    font-family: 'Lato', sans-serif;
}

.total td small {
    font-size: 15px;
}

.total td input[type="text"] {
    width: auto;
    padding: 7px;
    height: 35px;
    line-height: 35px;
}

.total tr:hover {
    background-color: transparent;
}

.total tr.total-cash {
    border-top: 1px dotted #ccc;
}

.total tr.total-cash strong {
    font-size: 115%;
    font-weight: bold;
}

.total tr.total-cash th {
    padding-top: 15px;
}

.total tr.total-cash td {
    color: var(--p-focus-color);
    padding-top: 10px;
}

.total tr.total-cash td span {
    font-size: 14px;
    display: block;
    color: var(--gray-600);
}

.total.full {
    margin-bottom: 0;
}

.total.full table {
    width: 100%;
}

.total.full tr {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
}

.total.full th {
    justify-content: flex-start;
    padding: 0;
    font-size: 14px;
    align-items: center;
}

.total.full th p {
    margin: 0;
    font-size: 16px;
}

.total.full td {
    font-size: 18px;
    white-space: nowrap;
}

.total.full tr.total-cash {
    margin-top: 10px;
}

.total.full .form-actions {
    margin-left: 0.5rem;
}

.coupon {
    padding-right: 0;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin-top: 0.5rem;
    position: relative;
    padding-bottom: 30px;
}

.coupon a {
    display: block;
    padding: 5px 0;
    font-size: 14px;
    margin-left: 1rem;
}

.checkout-page .coupon input {
    width: 270px;
    margin-bottom: 0;
    line-height: 22px;
}

.coupon .add-btn {
    font-size: 15px;
    font-weight: 300;
    width: 80px;
    min-width: auto;
    padding: 8px 5px;
    margin-left: 4px;
}

.coupon p {
    position: absolute;
    bottom: 0;
    width: 100%;
    text-align: left;
    color: var(--p-focus-color);
    margin-bottom: 0;
    font-size: 14px;
}

/* 優惠券modal */
.coupon-list.modal-dialog {
    width: 750px;
}

.coupon-list .modal-body,
.policy .modal-body {
    max-height: 70dvh;
    padding: 1.5rem;
    overflow-y: auto;
}

.policy .modal-body * {
    font-family: "Arial", "Noto Sans TC", "PingFang TC", "Microsoft JhengHei", "sans-serif" !important;
}

.coupon-list .modal-header,
.coupon-list .modal-footer {
    border-color: #f5f6f8;
}

.coupon-list .data-table th {
    border: 0;
    border-bottom: 1px solid var(--gray-300);
    background-color: var(--p-main-color);
    color: #fff;
    text-align: left;
}

.coupon-list .data-table tbody tr {
    border: 0;
    border-bottom: 1px solid var(--gray-300);
}

.coupon-list .data-table tr td {
    padding: 8px;
    color: var(--gray-900);
    text-align: center;
    border: 0;
}

.coupon-list .data-table tr {
    position: relative;
}

.coupon-list .data-table tr td.tick {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.coupon-list .data-table .coupon-title {
    text-align: left;
    position: relative;
    padding-left: 35px;
    width: 90%;
}

.coupon-list .data-table .coupon-title label {
    justify-content: flex-start;
    padding-left: 0;
}

.coupon-list .data-table .coupon-title p {
    margin: 0;
}

.coupon-list .data-table .coupon-title span {
    color: var(--gray-600);
    font-size: 14px;
    font-weight: 300;
}

.coupon-list .data-table .coupon-title span.coupon-no {
    background-color: var(--p-font-color);
    padding: 0 5px;
    color: #fff;
    border-radius: 3px;
    font-size: 13px;
}

.coupon-list .data-table tr td label {
    width: 100%;
    text-align: left;
    position: absolute;
    padding: 17px 8px;
    justify-content: flex-end;
    display: flex;
    align-items: center;
    top: 0;
    left: 0;
    height: 100%;
}

.coupon-list .data-table tr td label input[type=radio].ace.input-lg+.lbl::before {
    top: -12px;
    margin-right: 0;
}

.coupon-list .data-table input {
    width: 25px;
    height: 25px;
    margin: 0;
}

@media(max-width: 992px) {
    .total-block {
        flex-direction: column;
        align-items: flex-end;
    }

    .total-block.no-coupon {
        flex-direction: row;
    }

    .coupon {
        margin: 0 0 1rem 0;
        /* flex-direction: row-reverse; */
    }

    /* .coupon p{
        text-align: right;
    } */
    .checkout-page .coupon input {
        width: 200px;
    }

    .coupon a {
        margin: 0 0 0 1rem;
    }

    .coupon-list .data-table tr td.tick {
        padding: 0;
    }

    .coupon-list .data-table tr td.tick label {
        /* position: inherit;
        padding: 0;
        width: 24px;
        height: 24px;
        margin: 0; */
    }
}

@media(max-width: 767px) {

    .coupon-list .modal-body {
        padding: 10px;
    }
}

@media(max-width: 575px) {
    .total {
        font-size: 14px;
    }

    .total td {
        width: 90px;
        font-size: 16px;
    }

    .total th {
        padding-left: 0;
        padding-right: 0;
    }

    .total.full th {
        align-items: flex-start;
        flex-direction: column;
        font-size: 14px;
    }

    .total.full td {
        /* font-size: 16px; */
    }

    .total.full .form-actions {
        margin-left: 0;
        margin-top: 0.5rem;
    }

    .coupon, .coupon>div {
        width: 100%;
    }

    .coupon a {
        margin-left: 10px;
        white-space: nowrap;
    }

    .checkout-page .coupon input {
        width: 70%;
    }

    .coupon .add-btn {
        width: 25%;
    }
}

/***未符合折扣活動**/
.discount-event {
    margin-top: 2rem;
}

.discount-event h5 {
    font-size: 16px;
    font-weight: 400;
    color: var(--p-font-color);
    margin-bottom: 0.75rem;
}

.discount-list {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    border: 0px solid var(--gray-300);
    padding: 5px;
    margin-bottom: 1rem;
    position: relative;
    -webkit-box-shadow: 0 0 5px 0 rgb(0 0 0 / 10%);
    -moz-box-shadow: 0 0 5px 0 rgb(0 0 0 / 10%);
    box-shadow: 0 0 5px 0 rgb(0 0 0 / 10%);
}

.discount-list::before {
    content: "";
    width: 21px;
    height: 36px;
    background: url(../images/icon/discount-circle.png) no-repeat;
    background-size: 100%;
    position: absolute;
    top: 50%;
    margin-top: -17px;
    left: -3px;
}

.discount-list h5 {
    width: 100px;
    min-height: 100px;
    display: flex;
    align-items: center;
    margin: 0;
    justify-content: center;
    background-color: #61C9C1;
    color: #fff;
    font-size: 20px;
    line-height: 25px;
    font-weight: 500;
    letter-spacing: 1px;
}

.discount-list .txt {
    width: calc(100% - 105px);
    background-color: #f4f2f2;
    padding: 0.5rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

.discount-list .txt p {
    color: var(--p-font-color);
    font-size: 16px;
    line-height: 1.3;
    margin: 5px 0 0 0;
}

.discount-list span.thumb {
    background-color: var(--p-main-color);
    padding: 2px 10px;
    border-radius: 3px;
    color: #fff;
    font-size: 14px;
}

.discount-list span.margin {
    font-size: 14px;
    color: var(--p-focus-color);
}

.discount-list .discount {
    color: var(--p-focus-color);
    font-size: 16px;
    line-height: 20px;
    position: absolute;
    right: 0;
    top: 8px;
}


.discount-list.no h5 {
    background-color: #e4e4e4;
    color: #808080;
}

.discount-list.no span.thumb {
    background-color: #808080;
}

.miss .discount-list li p {
    width: calc(100% - 90px);
}

.miss .discount-list li span.thumb {
    color: #999;
    background-color: #f7f7f7;
}

.miss .discount-list li p.txt span {
    color: var(--p-main-color);
}

/***加價購***/
.shop-additional {
    margin-top: 1rem;

}

.full-page .shop-additional .title {
    margin-bottom: 0;
    padding: 1.1rem 2rem 1rem 3.25rem;
    font-size: 20px;
    line-height: 0.8;
    letter-spacing: normal;
    color: #fff;
    border-radius: 10px 10px 0 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    background: url(../images/icon/additional-icon.png) no-repeat 15px center;
    background-color: var(--p-main-color);
    background-size: 30px;
}

.shop-additional .shop-list {
    background-color: var(--gray-100);
    padding: 2rem 2rem 1.5rem 2rem;
    border-radius: 0 0 10px 10px;
}

.shop-additional .shop-list .shop-product {
    background-color: #fff;
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1rem;
    -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
}

.shop-additional .shop-list .shop-grid .shop-product .product-body {
    padding: 0;
}

.shop-additional .shop-list .shop-list-body.shop-grid {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    column-gap: 1rem !important;
}

.shop-additional .shop-list .product-image a,
.shop-campaign .shop-list .product-image a {
    border: 0 !important;
    padding: 0 !important;
}

.shop-additional .shop-list .shop-product .product-body .name {
    font-size: 15px;
    height: 35px;
    letter-spacing: 0;
}

/* .shop-additional .shop-list .shop-product .price .new-price{
    font-size: 23px;
    display: inline-flex;
    align-items: center;
} */
.shop-additional .shop-list .shop-product .price {
    margin-bottom: 0.25rem;
    margin-top: 0.5rem;
}

.shop-additional .shop-list .shop-product .price .new-price span {
    font-size: 160%;
}

.shop-additional .shop-list .shop-product .price .old-price {
    font-size: 15px;
    font-weight: 300;
}

.shop-additional .pro-select select {
    font-size: 15px;
    height: 40px;
    line-height: 40px;
    border-radius: 40px;
    padding: 0 12px;
    border: 1px solid #e3e3e3 !important;
    background-color: #fff;
}

.shop-additional .shop-list .product-button {
    justify-content: space-between !important;
    margin: 0 !important;
}

.shop-additional .shop-list .add-to-cart {
    width: calc(100% - 85px);
    min-width: auto;
    letter-spacing: 0;
    font-weight: normal;
    height: 40px;
    line-height: 40px;
}

.shop-additional .shop-list .quantity {
    width: 80px;
}

.shop-additional .shop-list .quantity input[type="number"] {
    height: 40px;
    border: 1px solid #e3e3e3 !important;
}

.shop-additional .pro-select select,
.shop-additional .shop-list .quantity input[type="number"],
.shop-additional .shop-list .add-to-cart {
    border-radius: 6px;
}

.shop-additional .quantity input[type="number"] {
    padding: 0 30px;
    font-size: 15px;
}

.shop-additional .quantity input[type="number"]:focus {
    border-color: #ccc !important;
}

.shop-additional .product-button .quantity span {
    width: 30px;
    height: 40px;
}

.shop-additional .product-button .quantity span i {
    font-size: 16px;
}

@media(max-width: 1199px) {
    .shop-additional .shop-list .shop-list-body.shop-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media(max-width: 992px) {
    .shop-additional .shop-list .shop-list-body.shop-grid {
        grid-template-columns: 1fr 1fr;
    }

    .shop-additional .shop-list {
        padding: 1rem 1rem 0.5rem 1rem;
    }
}

@media(max-width: 767px) {
    .shop-additional {
        background-color: transparent;
        padding: 0;
    }

    .shop-additional .shop-list .shop-product {
        padding: 0.75rem;
    }

    .shop-additional .product-button .quantity span {
        width: 40px;
    }
}

@media(min-width: 575px) {
    .shop-additional .shop-list .shop-product {
        display: flex;
        justify-content: space-between;
    }

    .shop-additional .shop-list .shop-grid .shop-product .product-image {
        width: 30%;
        margin-bottom: 0;
    }

    .shop-additional .shop-list .shop-grid .shop-product .product-image img {
        max-width: 100%;
    }

    .shop-additional .shop-list .shop-grid .shop-product .product-body {
        width: 70%;
        text-align: left;
    }

    .shop-additional .shop-list .shop-product .price {
        justify-content: flex-start;
    }
}

@media(max-width: 575px) {
    .shop-additional .shop-list {
        margin: 0;
    }

    .shop-additional .shop-list .shop-grid .shop-product .product-image img {
        max-width: 60%;
    }

    .shop-additional .shop-list .shop-list-body.shop-grid {
        grid-template-columns: 1fr 1fr;
    }

    .shop-additional .shop-list .product-button {
        flex-direction: column;
        margin: 0 !important;
    }

    .shop-additional .shop-product .product-body>div, .shop-additional .shop-list .quantity {
        margin-bottom: 0.25rem;
    }

    .shop-additional .shop-list .product-button>* {
        width: 100% !important;
    }
}

/***活動專區***/


@media(max-width: 767px) {
    .shop-campaign .banner {
        margin: -1rem;
    }
}

.campaign-heading {
    position: relative;
}

.full-page .campaign-heading h1.title {
    font-size: 32px;
    font-weight: 400;
    display: flex;
    flex-flow: wrap;
    gap: 0.25rem;
    margin-bottom: 0.5rem;
}

.campaign-close {
    font-size: 16px;
    letter-spacing: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-weight: normal;
    color: var(--gray-600);
}

.campaign-close .tag {
    font-size: 14px;
    background-color: var(--gray-600);
    padding: 4px 8px;
    border-radius: 4px;
    color: #fff;
}

.campaign-heading .title-block {
    background-color: #fff;
    border-radius: 8px;
    padding: 2rem;
    margin: -2rem 1rem 2rem 1rem;
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 3rem;
    width: calc(100% - 2rem);
    -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
    -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
}

@media (max-width: 1199px) {
    .campaign-heading .title-block {
        gap: 0.5rem;
    }

    .full-page .campaign-heading h1.title {
        letter-spacing: 0.5px;
    }
}

@media (max-width: 992px) {
    .campaign-heading .title-block {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767px) {
    .campaign-heading .title-block {
        gap: 1rem;
        margin: -2rem 0.5rem 2rem 0.5rem;
        width: calc(100% - 1rem);
        padding: 1.5rem;
    }
}

@media (max-width: 576px) {
    .campaign-heading .title-block {
        padding: 1rem;
    }
}

.campaign-heading .date {
    font-size: clamp(14px, 2vw, 16px);
    letter-spacing: 0.5px;
}

/***倒數區塊***/
.campaign-heading .countdown-block {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.25rem;
    white-space: nowrap;
}

@media (max-width: 992px) and (min-width: 768px) {
    .campaign-heading .countdown-block:not(.sticky-top) {
        flex-direction: row;
        justify-content: space-between;
        width: 100%;
        align-items: center;
    }
}

@media (max-width: 767px) {
    .campaign-heading .countdown-block:not(.sticky-top) {
        width: 100%;
        align-items: stretch;
    }
}

.countdown {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1rem;
    font-weight: 500;
    color: var(--p-focus-color);
}

.countdown div {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.countdown span {
    display: flex;
    align-items: center;
    border-radius: 2px;
    justify-content: center;
}

.countdown h6 {
    font-size: 1rem;
    margin-bottom: 0;
    color: var(--gray-900);
    display: flex;
    align-items: center;
}

.countdown h6::before {
    content: "";
    background-image: url(../images/icon/icon-flash.svg);
    background-size: 100%;
    width: 25px;
    height: 25px;
}

.countdown .count-num {
    font-size: 24px;
    font-weight: 600;
}

.countdown .count-unit {
    font-weight: 400;
}

@media (max-width: 1199px) and (min-width: 992px) {
    .countdown:not(.sticky-top .countdown) {
        flex-direction: column;
        gap: 0;
    }

    .countdown .count-num {
        font-size: 20px;
        font-weight: 600;
    }
}

@media (max-width: 767px) {
    .countdown:not(.sticky-top .countdown) {
        width: 100%;
        align-items: stretch;
        border-top: 1px solid var(--gray-300);
        padding-top: 1rem;
        justify-content: center;
    }

    .countdown .count-num {
        font-size: 22px;
    }
}

@media (max-width: 576px) {
    .countdown:not(.sticky-top .countdown) {
        justify-content: space-between;
    }

    .countdown, .countdown h6 {
        font-size: 14px;
    }

    .countdown .count-num {
        font-size: 20px;
    }
}

/***倒數區塊fixed***/
.campaign-heading .countdown-block.sticky-top {
    position: fixed;
    width: 100%;
    left: 0;
    top: 80px;
    background-color: var(--gray-900);
    padding: 0.25rem 0;
    align-items: center;
}

@media (max-width: 576px) {
    .campaign-heading .countdown-block.sticky-top {
        top: 60px;
    }
}

.campaign-heading .countdown-block.sticky-top .btn {
    display: none;
}

.sticky-top .countdown {
    gap: 0.5rem;
}

.sticky-top .countdown span {
    gap: 0.5rem;
}

.sticky-top .countdown h6 {
    color: #fff;
    font-weight: 400;
}

.sticky-top .countdown .count-num {
    font-size: 20px;
}

.sticky-top .countdown .count-unit {
    color: #fff;
}


.shop-campaign .editor-block {
    margin-bottom: 2rem;
}

.shop-campaign .editor-block img {
    min-width: 100%;
}

.shop-campaign .shop-list .shop-list-body.shop-grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 2rem;
}

.shop-campaign .shop-list .shop-product {
    background-color: #fff;
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 2rem;
    border: 1px solid var(--gray-300);
    position: relative;
    align-items: flex-start;
    cursor: pointer;
}

.shop-campaign .shop-list .shop-product.closed {
    cursor: default;
}

.shop-campaign .shop-list .shop-product.closed:hover {
    border: 1px solid var(--gray-300);
}

.shop-campaign .shop-list .shop-product.closed .product-image::before {
    display: flex;
    align-items: center;
    justify-content: center;
    content: "已結團";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 2;
    color: #fff;
    border-radius: 8px;
}

.shop-campaign .shop-list .shop-product:hover {
    border: 1px solid var(--gray-900);
}

.shop-campaign .shop-list .shop-product .product-image img {
    max-width: 100%;
}

.shop-campaign .pro-tag {
    margin: 0;
    position: absolute;
    z-index: 1;
    left: 0;
    top: 0;
}

.shop-campaign .pro-tag span {
    background-color: #fff;
    color: var(--p-main-color);
    border-color: var(--p-main-color);
}

.shop-campaign .shop-list .shop-product .product-body .name {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.4;
    height: auto;
    margin-bottom: 0.5rem;
}

.shop-campaign .shop-product .product-body .description {
    text-align: justify;
    margin-bottom: 0.5rem;
}

.shop-campaign .shop-product .product-body .description p {
    margin-bottom: 0;
}

.shop-campaign .shop-list .shop-product .price {
    justify-content: flex-start;
    align-items: baseline;
    margin-bottom: 0;
}

.shop-campaign .shop-product .price .new-price span {
    font-size: 22px;
    font-weight: bold;
}

.shop-campaign .shop-list .shop-product .price .new-price {
    font-size: 14px;
}



.pick-block {
    padding: 1rem;
    margin-bottom: 2rem;
    border-radius: 10px;
    background: #fff;
    -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
    -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);
}

.pick-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
}

.pick-title .text {
    font-size: 16px;
    line-height: 1.5;
    white-space: nowrap;
}

.pick-title .text a {
    font-size: 105%;
    font-weight: 500;
}

.pick-title .text br {
    display: none;
}

.pick-title .text .add-btn {
    padding: 7px;
    min-width: 120px;
    font-size: 15px;
    border-radius: 40px;
}

.pick-title .action {
    display: flex;
    align-items: center;
}

.pick-title .price {
    margin-bottom: 0;
    flex-flow: row wrap;
}

.pick-title .new-price.original-price {
    margin-right: 1rem;
    color: var(--gray-500);
}

.pick-title .new-price.original-price span {
    color: var(--gray-500);
    font-size: 18px !important;
    text-decoration: line-through;
}

.pick-title .new-price.original-price span small {
    font-size: 100%;
}

.pick-title .add-to-cart {
    margin-left: 1rem;
}

.pick-list {
    position: relative;
}

.pick-list .swiper {
    padding: 0 0.75rem 0 0;
    position: relative;
}

.pick-list .swiper .grid-product {
    padding: 10px;
    margin: 1rem 0 0.25rem 0;
    position: relative;
    border: 0;
    background-color: transparent;
}

.pick-list .swiper .grid-product .image {
    border-radius: 0;
}

.pick-list .grid-product .pro-body {
    margin: 0.25rem 0 0 0;
    padding: 0;
    line-height: 1.2;
    min-height: 40px;
}

.pick-list .grid-product .name {
    font-size: 12px;
    /* height: 35px;
    display: inline; */
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    box-sizing: border-box;
    height: 28px;
}

.pick-list .amount {
    background-color: var(--gray-900);
    color: #fff;
    border-radius: 3px;
    display: flex;
    width: fit-content;
    padding: 0px 5px;
    margin: auto;
    margin-top: 0.25rem;
    align-items: center;
    justify-content: center;
    line-height: 1.2;
    font-size: 14px;
}

.pick-list .remove {
    background-color: var(--gray-400);
    color: #fff;
    width: 30px;
    height: 30px;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    right: -10px;
    top: -10px;
}

.pick-list .btndrop {
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    background: url(../images/icon/btndrop.png) no-repeat;
    background-size: cover;
    width: 40px;
    height: 30px;
    margin: auto;
    transition: all 0s ease 0s;
    display: none;
}

.pick-list .btndrop.collapsed {
    transition: all 0s ease 0s;
    transform: rotate(180deg);
    display: flex;
}

.pick-list .swiper-button-next, .pick-list .swiper-button-prev {
    margin-top: calc(-15px - (var(--swiper-navigation-size)/ 2));
}

.sticky-top.pick-block {
    position: fixed;
    top: 80px;
    width: 100%;
    left: 0;
    z-index: 2;
    padding: 0.5rem 0;
    border-radius: 0;
}

.sticky-top .pick-title {
    padding: 8px 0;
}

.sticky-top .grid-product .image img {
    max-width: 50%;
}

.sticky-top .pick-list .btndrop {
    display: flex;
}


/***加價區/贈品區***/


.shop-campaign .campaign-additional .title {
    background-color: var(--p-main-color);
    text-align: center;
    color: #fff;
    padding: 0.5rem;
    border-radius: 6px;
    font-size: 22px;
    line-height: 1.5;
}

@media(min-width: 575px) {
    .shop-campaign .shop-list .shop-product {
        display: flex;
        justify-content: space-between;
        padding: 1.5rem;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-body,
    .shop-campaign .campaign-additional .shop-list .shop-grid .shop-product .product-body {
        width: calc(100% - 170px);
        padding: 0;
        text-align: left;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-image,
    .shop-campaign .campaign-additional .shop-list .shop-grid .shop-product .product-image {
        width: 150px;
    }

    .shop-campaign .shop-list .shop-product .product-body .product-button {
        width: 400px;
        justify-content: flex-start;
    }

    .shop-campaign .product-button .quantity {
        width: 150px;
        margin-right: 0.25rem;
    }

}

@media(min-width: 768px) {

    .shop-campaign .shop-list .shop-grid .shop-product .product-body,
    .shop-campaign .campaign-additional .shop-list .shop-grid .shop-product .product-body {
        width: calc(100% - 200px);
        text-align: left;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-image,
    .shop-campaign .campaign-additional .shop-list .shop-grid .shop-product .product-image {
        width: 180px;
    }

}

@media(min-width: 992px) {
    .shop-campaign .shop-list .shop-grid .shop-product .product-body {
        width: calc(100% - 200px);
        padding: 0px 180px 0px 20px;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-image {
        width: 200px;
        margin-bottom: 0;
    }

    .shop-campaign .shop-list .shop-product .product-body .product-button {
        position: absolute;
        flex-direction: column;
        right: 0;
        top: 0;
        width: 160px;
    }

    .shop-campaign .shop-list .shop-product .product-body .product-button>* {
        width: 100%;
        min-width: auto;
        margin-bottom: 0.5rem;
    }

    .shop-campaign .campaign-additional .shop-list .shop-product .product-body .product-button {
        position: inherit;
        width: 100%;
        flex-direction: row;
        justify-content: flex-start;
    }

    .shop-campaign .campaign-additional .shop-list .shop-product .product-body .product-button>* {
        width: 160px;
        margin-right: 0.25rem;
    }
}

@media(max-width: 1199px) and (min-width: 992px) {
    .pick-title .text br {
        display: block;
    }
}

@media(max-width: 575px) {
    .pick-title .text {
        white-space: inherit;
    }
}

@media(max-width: 1199px) {
    .shop-campaign .campaign-additional .shop-list .shop-list-body.shop-grid {
        grid-template-columns: 1fr;
    }
}

@media(max-width: 992px) {
    .full-page .campaign-heading h1.title {
        font-size: 28px;
    }

    .pick-block {
        padding: 1.5rem;
    }

    .pick-block .container {
        max-width: 100%;
        padding: 0;
    }

    .sticky-top.pick-block .container {
        padding-right: 15px;
        padding-left: 15px;
    }

    .pick-title {
        flex-direction: column;
        align-items: flex-start;
    }

    .pick-title .action {
        margin-top: 0.25rem;
        width: 100%;
        justify-content: flex-end;
    }

    /* .pick-title .action .add-to-cart {
        position: absolute;
        right: 0;
        top: 0.25rem;
    } */
    .pick-title .price {
        margin-top: 0;
        font-size: 14px;
    }

    .shop-campaign .campaign-additional .title {
        font-size: 20px;
    }
}

@media (max-width: 767px) {
    .pick-title .text {
        font-size: 14px;
    }
}

@media (max-width: 575px) {
    .full-page .campaign-heading h1.title {
        font-size: 22px;
        letter-spacing: 0.5px;
        font-weight: 500;
        line-height: 1.4;
    }

    .campaign-heading>p {
        font-size: 15px;
    }

    .pick-title {
        padding: 8px 0;
    }

    .pick-block {
        position: fixed;
        top: auto !important;
        bottom: 0 !important;
        width: 100%;
        left: 0;
        z-index: 5 !important;
        padding: 0.5rem 0;
        border-radius: 0;
        margin-bottom: 0;
    }

    .pick-block .container {
        padding-right: 15px;
        padding-left: 15px;
        display: flex;
        flex-direction: column-reverse;
    }

    /* .pick-title {
        margin: 0 !important;
        border-bottom: 0;
        padding: 0 !important;
    } */

    /* .pick-title .price {
        flex-direction: column;
    } */
    .pick-title .action .add-to-cart {
        position: inherit;
        min-width: 160px;
        margin-left: 0;
    }

    .sticky-top+.editor-block, .sticky-top+.shop-list {
        margin-top: 0;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-image img {
        max-width: 60%;
    }

    .shop-campaign .shop-list .shop-grid .shop-product .product-body {
        text-align: left;
        padding: 0;
    }

    .shop-campaign .shop-list .shop-product .product-body .product-button {
        justify-content: space-between;
    }

    .shop-campaign .product-button .quantity {
        width: 140px;
    }

    .shop-campaign .shop-list .add-to-cart {
        min-width: calc(100% - 150px);
        min-width: 100%;
    }

    .shop-campaign .shop-product .price .new-price span {
        font-size: 20px;
    }

    .pick-title .new-price.original-price span {
        font-size: 16px !important;
    }

    .pick-title .action {
        justify-content: space-between;
        width: 100%;
        margin-top: 0.25rem;
    }

    .grid-product .image img {
        max-width: 60%;
    }

    .pick-list {
        margin-bottom: 0.5rem;
        display: flex;
        flex-direction: column-reverse;
    }

    .pick-list .swiper-button-next, .pick-list .swiper-button-prev {
        margin-top: calc(20px - (var(--swiper-navigation-size)/ 2));
    }

    .pick-list .btndrop {
        display: flex;
        margin-top: 0;
        transform: rotate(180deg);
    }

    .pick-list .btndrop.collapsed {
        transform: rotate(0deg);
    }

}

.shop-campaign.closed {
    width: 800px;
    max-width: 100%;
    margin: auto;
    text-align: left;

    .banner {
        width: 200px;
        margin: auto;
        border-radius: 8px;
        overflow: hidden;
        margin-bottom: 1rem;
    }

    .add-btn {
        @media (max-width: 575px) {
            width: 100%;
        }
    }
}

.order-btn, .btn, .add-btn, .process-button, .swal2-confirm {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 32px;
    gap: 4px;
    font-size: 16px;
    font-weight: normal;
    color: #fff !important;
    background-color: var(--gray-900);
    min-width: 180px;
    border-radius: 8px;
    white-space: nowrap;
    text-align: center;
    height: 48px;
    border: 0;
}

.order-btn:last-child {
    margin-right: 0;
}

.add-btn.line-login, .add-btn.btn-line, .btn.btn-line {
    background-color: #06c755;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.add-btn.line-login::before {
    content: "";
    display: inline-flex;
    width: 30px;
    height: 30px;
    background-image: url(../images/icon/icon-line-w.png);
    background-repeat: no-repeat;
    background-size: 100%;
}

.add-btn.line-login:hover, .add-btn.btn-line:hover, .btn.btn-line:hover {
    background-color: #029f42;
}

.divider {
    clear: both;
}

.add-btn+.add-btn,
.order-btn+.order-btn {
    margin-left: 5px !important;
}

.add-btn.btn-sm,
.btn.btn-sm {
    padding: 8px 12px;
    min-width: fit-content;
    height: 40px;
}

.add-btn.btn-icon,
.btn.btn-icon {
    padding: 8px;
    min-width: auto;
}

.add-btn.btn-xs,
.btn.btn-xs {
    padding: 4px 8px !important;
    font-size: 13px;
    border-radius: 8px;
    min-width: 90px;
    height: 34px;
}

.add-btn.btn-gry {
    background-color: transparent;
    border: 1px solid #000;
    color: var(--gray-900) !important;
}

.add-btn:disabled {
    cursor: default;
    background-color: var(--p-main-color);
    opacity: 0.5;
}

.add-btn.btn-outline {
    background-color: #fff;
    border: 1px solid var(--p-main-color);
    color: var(--p-font-color) !important;
}

.add-btn.btn-outline:hover {
    background-color: #fff;
    border: 1px solid var(--p-main-color);
    color: var(--p-font-color) !important;
}

.add-btn.btn-outline.btn-delete:hover {
    background-color: var(--p-focus-color);
    border-color: var(--p-focus-color);
}

.add-btn.btn-red {
    background-color: var(--p-focus-color);
}

.add-btn.btn-red:hover {
    background-color: var(--p-focus-color);
}

span.add-btn {
    cursor: default;

}

.full {
    width: 100% !important;
}

.btn.btn-link {
    color: var(--gray-900) !important;
    min-width: auto;
    gap: 0.25rem;
    background-color: transparent !important;
    padding: 0;
}

/****checkout-page***************/
.checkout-page {
    position: relative;
    margin: 1rem 0;
}

.checkout-page .form-container, .payment-select1, .complete-block, .checkout-page .cart-tabs {
    margin: auto;
    width: 1000px;
    max-width: 100%;
}

.checkout-page .form-container, .member-page .form-container {
    background-color: transparent;
    padding: 0;
}

.checkout-page .form-container .form-block,
.member-page .form-container .form-block,
.payment-select1,
.display {
    border: 1px solid var(--gray-300);
    padding: 2rem;
    margin-bottom: 1rem;
    border-radius: 8px;
}

@media (max-width: 1199.98px) {

    .checkout-page .form-container .form-block,
    .member-page .form-container .form-block,
    .payment-select1, .display {
        padding: 1.25rem;
    }
}

.checkout-page .form-container h4, .payment-select1 h4, .member-page .form-container h4 {
    clear: both;
    border-bottom: 1px dotted var(--gray-400);
    font-size: 24px;
    font-weight: normal;
    padding-bottom: 15px;
    color: var(--p-font-color);
    margin-bottom: 20px;
    margin-top: 0;
}

.form-container h4.d-flex {
    align-items: center;
}

.checkout-page .form-container h4 label {
    margin: 0 0 0 12px;
    font-size: 14px;
}

.checkout-page .form-container h4 label input[type=checkbox].ace.input-lg+.lbl::before {
    top: -5px;
}

.member-page .form-container h4 .date {
    color: #999;
    font-size: 15px;
    font-weight: 300;
}

.text-link {
    text-decoration: underline;
}

.member-page .form-container h4 .text-link {
    color: #999;
    font-size: 15px;
    font-weight: 300;
}

.form-block .btndrop {
    position: relative;
    display: block;
    padding: 4px 16px;
    color: #fff;
    border-radius: 8px;
    height: 40px;
}

.form-block .form-row+.btndrop {
    margin-top: 0.5rem;
}

.form-block .btndrop span {
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.form-block .btndrop[data-bs-toggle='collapse'] span:after {
    content: "\f107";
    font-family: 'FontAwesome';
    font-size: 21px;
    margin-left: 0.25rem;
}

.form-block .btndrop[data-bs-toggle='collapse'][aria-expanded="true"] span:after {
    content: "\f106";
}

.form-block .shop-cart-table td {
    padding: 12px;
}

.form-block .shop-cart-table .cart_table_title {
    border-bottom: 0;
    background-color: #eff7f7;
    background-color: var(--p-main-color);
    color: #fff;
}

@media (min-width: 1200px) {

    .checkout-page .form-block>.row .col-xl-8,
    .checkout-page .form-block .tab-pane>.row .col-xl-8 {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 90%;
        flex: 0 0 90%;
        max-width: 90%;
    }
}

.checkout-page .cart-login {
    margin-bottom: 1.25rem;
    align-items: center;
    display: flex;
    justify-content: space-between;
    font-size: 16px;
    border: 1px solid var(--gray-300);
    padding: 0.75rem;
}

.checkout-page .cart-login p {
    margin: 0 0.5rem;
    width: 100%;
}

.checkout-page .cart-login .add-btn {
    padding: 8px;
    min-width: 130px;
    margin-left: 0.5rem;
}

.discount-check {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.total th i {
    font-size: 16px;
    margin-right: 5px;
}

.discount-check i {
    font-size: 21px;
    color: var(--p-main-color);
}


@media (max-width: 992px) {
    .checkout-page .cart-login {
        font-size: 16px;
        position: relative;
    }
}


@media (max-width: 575px) {
    .checkout-page .cart-login p {
        margin: 0;
        position: relative;
        width: 100%;
    }

    .checkout-page .cart-login p+p {
        margin-top: 0.5rem;
    }

    .add-btn.btn-sm {
        padding: 8px 12px !important;
        min-width: fit-content;
    }
}

@media (max-width: 379px) {
    .add-btn.btn-sm {
        min-width: fit-content;
    }
}

.faq-block {
    color: var(--gray-600);
}

.faq-block h5 {
    color: var(--gray-900);
}

@media (max-width: 992px) {
    .faq-block h5 {
        font-size: 18px;
    }
}

/***********payment-select**********/
.payment-select {
    margin: 10px 0;
    padding: 10px 20px 6px 20px;
    border: 1px solid var(--gray-300);
    clear: both;
    text-align: right;
}

.payment-select1 ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
    display: flex;
    align-items: center;
    flex-flow: row wrap;
}

.payment-select1 ul li {
    color: var(--gray-900);
    display: inline-block;
}

.payment-select1 ul li:last-child {
    padding-right: 0;
}

.payment-select1 ul li a {
    color: #999;
    text-decoration: none;
}

.payment-select1 .second li {
    padding-left: 34px;
}

.payment-select1 .second li:last-child {
    border: 0;
}

.payment-select1 ul li span.title {
    color: var(--p-font-color);
    font-size: 16px;
    width: 100%;
    letter-spacing: 0;
}

.payment-select1 ul li span.title i {
    font-size: 20px;
    margin-left: 5px;
}

.payment-select1 ul li span.title img {
    height: 30px;
}

.payment-select1 span.txt {
    width: 70%;
    font-size: 14px;
    line-height: 25px;
    text-align: justify;
    float: left;
}

.payment-select1 ul li label {
    padding: 0;
    margin: 0;
    font-weight: normal;
    cursor: pointer;
    border: 1px solid transparent;
}

.payment-select1 ul li.active label {
    border-color: var(--p-main-color);
}

.payment-select1 img {
    display: inline-block;
}

.payment-select1 .select_container {
    margin: 0 0 0 5px;
    width: auto;
    display: inline-grid;
}

.payment-select1 img, .payment-select1 .txt2 a {
    display: inline-block;
    color: #444;
}

.payment-select1 input[type=radio].ace+.lbl {
    padding-left: 0;
}

.payment-select1 input[type=radio].ace.input-lg+.lbl::before {
    position: static;
}

.payment-select1 input[type=radio].ace.input-lg:checked+.lbl::before {
    content: '\f00c';
    font-size: 16px;
}

.payment-select.selected {
    padding: 15px 20px;
}

.payment-select.selected strong {
    color: #EE778C;
}

.payment-select label {
    margin-right: 10px;
}

.payment-select1 .form-block {
    border: 0 !important;
    background-color: var(--gray-100);
    margin: 0 !important;
}

.payment-select1 .form-block+.form-block {
    margin-top: -1rem !important;
}

.payment-select1 .form-block h5 {
    font-size: 20px;
    margin-bottom: 1rem;
}

.payment-select1 ul.payment-method {
    flex-direction: column;
    /* gap: 0.5rem; */
    margin-bottom: 1rem;
}

.payment-select1 ul.payment-method li {
    width: 100%;
    line-height: 40px;
}

.payment-select1 h4 .shipping-info1 {
    font-size: 14px;
    font-weight: 400;
}

.payment-select1 .shipping-info {
    margin-top: 1rem;
    padding: 1rem;
    background-color: var(--gray-100);
    transition: .2s;
    line-height: 1.4;
}

.payment-select1 .shipping-info p {
    margin-bottom: 0;
}

.payment-info p {
    font-size: 14px;
    color: var(--gray-600);
    margin: 0;
}

.payment-info hr {
    color: var(--gray-500);
    margin: 0.75rem 0;
}

.card-number {
    display: flex;
    align-items: center;
}

.card-number input+input {
    margin-left: 8px;
}

.card-number input+input::before {
    content: " - ";
    display: inline-flex;
    width: 20px;
    color: #666;
    font-size: 18px;
}

.card-number span {
    display: inline-flex;
    margin: 5px;
}

.complete-block {
    padding: 40px 50px;
    border: 1px solid var(--gray-300);
    margin-bottom: 30px;
    line-height: 1.5;
    font-size: 16px;
    border-radius: 8px;
}

.complete-block h2 {
    font-size: 28px;
    font-weight: 400;
    margin-bottom: 1rem;
    display: flex;

}

.complete-block h2::before {
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100%;
    content: "";
    width: 32px;
    height: 32px;
    margin-right: 0.5rem;
}

.complete-block h2.order-success::before {
    background-image: url(../images/icon/order-success.png?20250925d);
}

.complete-block h2.order-error::before {
    background-image: url(../images/icon/order-error.png?20250925d);
}

.complete-block p {
    margin-bottom: 0.5rem;
}

.complete-block p:last-child {
    margin-bottom: 0;
}

.complete-block a {
    font-weight: 400;
}

.complete-block strong {
    font-size: 18px;
    font-weight: 500;
}

.complete-block .credit-card {
    margin-top: 10px;
}

.complete-block .credit-card button {
    margin-left: 10px;
}

.complete-block ul.pay-info, .form-complete ul.pay-info {
    background-color: var(--gray-100);
    padding: 1rem;
    font-size: 16px;
    line-height: 1.8;
    width: 100%;
    margin-bottom: 0.25rem;
    list-style-type: none;
}

.complete-block ul.pay-info strong {
    font-size: 16px;
    font-weight: 400;
}

.cart-empty {
    width: 500px;
    max-width: 100%;
    margin: auto;
    text-align: center;
}

.cart-empty img {
    width: 200px;
}

.cart-empty p {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 3rem;
}

@media (max-width: 992px) {
    .payment-select1 ul.payment-method {
        flex-direction: row;
    }

    .payment-select1 ul.payment-method li {
        width: 50%;
    }

    /* .payment-select1 .form-block {
        margin-top: 1rem !important;
    } */
}

@media (max-width: 767px) {
    .payment-select1 .form-block h5 {
        font-size: 18px;
        font-weight: 500;
        margin-bottom: 0.5rem;
    }
}

@media (max-width: 575px) {
    .payment-select1 ul.payment-method li {
        width: 100%;
    }

    .complete-block ul.pay-info, .form-complete ul.pay-info {
        font-size: 14px;
    }

    .complete-block {
        padding: 20px;
        font-size: 14px;
    }

    .complete-block h2 {
        font-size: 24px;
        margin-bottom: 0.75rem;
    }

    .complete-block h2::before {
        width: 28px;
        height: 28px;
    }
}

input[type=checkbox].ace,
input[type=radio].ace {
    opacity: 0;
    position: absolute;
    z-index: 1;
    width: 18px;
    height: 18px;
    cursor: pointer;
}

label input[type=checkbox].ace,
label input[type=radio].ace {
    z-index: -100 !important;
    width: 1px !important;
    height: 1px !important;
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute;
}

input[type=checkbox].ace:checked,
input[type=radio].ace:checked,
input[type=checkbox].ace:focus,
input[type=radio].ace:focus {
    outline: none !important;
}

input[type=checkbox].ace+.lbl, input[type=radio].ace+.lbl {
    position: relative;
    margin: 0;
    cursor: pointer;
    padding-left: 30px;
}

input[type=checkbox].ace+.lbl::before, input[type=radio].ace+.lbl::before {
    cursor: pointer;
    font-family: fontAwesome;
    font-weight: normal;
    font-size: 12px;
    content: "\a0";
    border: 1px solid var(--p-main-color);
    box-shadow: none !important;
    border-radius: 0;
    display: inline-block;
    text-align: center;
    height: 16px;
    line-height: 14px;
    min-width: 16px;
    margin-right: 5px;
    position: absolute;
    left: 0;
}

input[type=checkbox].ace:checked+.lbl::before,
input[type=radio].ace:checked+.lbl::before {
    display: inline-block;
    content: '\f00c';
    border-color: var(--p-main-color);
    color: var(--p-main-color);
}

input[type=checkbox].ace:active+.lbl::before,
input[type=radio].ace:active+.lbl::before,
input[type=checkbox].ace:checked:active+.lbl::before,
input[type=radio].ace:checked:active+.lbl::before {
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px 1px 3px rgba(0, 0, 0, 0.1);
}

input[type=checkbox].ace.ace-checkbox-2+.lbl::before,
input[type=radio].ace.ace-checkbox-2+.lbl::before {
    box-shadow: none;
}

input[type=checkbox].ace.ace-checkbox-2:checked+.lbl::before,
input[type=radio].ace.ace-checkbox-2:checked+.lbl::before {
    background-color: #f9a021;
    border-color: #f9a021;
    color: #FFF;

}

input[type=checkbox].ace:disabled+.lbl::before,
input[type=radio].ace:disabled+.lbl::before,
input[type=checkbox].ace[disabled]+.lbl::before,
input[type=radio].ace[disabled]+.lbl::before,
input[type=checkbox].ace.disabled+.lbl::before,
input[type=radio].ace.disabled+.lbl::before {
    background-color: #DDD !important;
    border-color: #CCC !important;
    box-shadow: none !important;
    color: #BBB;
}

.checkbox label input[type=checkbox].ace+.lbl,
.radio label input[type=radio].ace+.lbl {
    margin-left: -10px;
}

input[type=radio].ace+.lbl::before {
    border-radius: 100%;
    font-size: 10px;
    font-family: FontAwesome;
    line-height: 15px;
    height: 17px;
    min-width: 17px;
    border: 1px solid #c8c8c8;
}

input[type=radio].ace:checked+.lbl::before {
    content: "\f111";
}

input[type=checkbox].ace.input-lg+.lbl::before {
    border-radius: 4px;
    font-size: 16px;
    height: 24px;
    line-height: 21px;
    min-width: 24px;
    top: -4px;

}

input[type=radio].ace.input-lg+.lbl::before {
    font-size: 14px;
    height: 24px;
    line-height: 22px;
    min-width: 24px;
    top: 0;
    color: var(--p-main-color);
    background-color: var(--gray-100);
    margin-right: 5px;
}


/***---------會員專區----------***/
section.member-page {
    padding: 3rem 0;
    min-height: calc(100dvh - 150px);
}

body:has(.breadcrumb-block) section.member-page {
    min-height: calc(100dvh - 210px);
}

.member-page .page-title.d-flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.member-page .page-title h2 {
    font-size: 36px;
    font-weight: 300;
    margin-bottom: 1rem;
}

.member-page .form-container .form-block .form-row.row {
    width: 90%;
    /* align-items: flex-start; */
}

.member-page .form-row.row .color1.flex-column {
    align-items: stretch;
}

.member-page .form-row.row .color1 .account-no a {
    color: var(--p-font-color);
}

.form-row.row .col-form-label,
.form-complete .form-row label {
    display: flex;
    text-align: right;
    min-height: 48px;
    justify-content: flex-end;
    align-items: center;
    padding-right: 1rem;
}

/* .member-page .form-row.row .col-form-label::after {
    content: "：";
} */
.member-page .form-row.row.form-actions .col-form-label::after {
    display: none;
}

.form-complete ul.pay-info {
    font-size: 16px;
    padding: 0.5rem;
}



@media (max-width: 1199px) {
    .member-page .form-container .form-block .form-row.row {
        width: 95%;
    }
}

@media (max-width: 575px) {
    .member-page .form-container .form-block .form-row.row {
        width: 100%;
        align-items: baseline;
        margin-left: 0;
    }

    .form-row.row .col-form-label, .form-complete .form-row label, .form-container .form-group .col-form-label {
        text-align: left;
        justify-content: flex-start;
        padding-right: 0;
        min-height: revert;
        color: var(--gray-600);
    }

    .col-sm-9.color1, .col-9.color1 {
        min-height: auto;
    }

    .form-complete ul.pay-info {
        font-size: 15px;
        line-height: 1.8;
    }
}

.member-page .third-party {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 10px;
    border-bottom: 1px dashed #dcdcdc;
    position: relative;
    margin-top: 10px;
}

.member-page .third-party p {
    flex: 1;
    margin: 0 0 0 1rem;
    font-size: 16px;
    color: var(--gray-900);
}

.member-page .third-party .btn {
    min-width: auto;
    width: 50px;
    height: 50px;
    padding: 5px;
    border-radius: 10px;
}

.member-page .third-party.yes .btn {
    cursor: default;
}

.member-page .third-party.none .btn {
    width: 170px;
}

.member-page .third-party.none .btn img {
    margin-right: 0.25rem;
}

.member-page .third-party .txt {
    font-size: 15px;
    line-height: 1.3;
    font-weight: 300;
    color: var(--p-focus-color);
}

.member-page .third-party .gray {
    color: #999;
}

@media only screen and (max-width: 575px) {

    .member-page .third-party.none {
        flex-direction: column;
        align-items: flex-start;
    }

    .member-page .third-party .txt {
        margin-top: 0.5rem;
    }

}

.block-account {
    margin-right: 2rem;
}

.block-account .title-header {
    display: none;
    position: relative;
    margin-bottom: 0;
    font-size: 16px;
}

.block-account .block-content>ul>li {
    margin-bottom: 5px;
    font-size: 16px;
    font-weight: 300;
}

.block-account .block-content>ul>li a {
    border: 1px solid var(--gray-900);
    padding: 12px 16px;
    display: block;
    color: #000;
    border-radius: 8px;
    /* background-color: #fff;
    -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%); */
}

.block-account .block-content>ul>li.current a,
.block-account .block-content>ul>li:hover a {
    background: var(--p-main-color);
    border-color: transparent;
    color: #fff;
}

.data-table {
    width: 100%;
    /* text-align: center; */
}

.data-table .add-btn {
    width: auto;
    padding: 7px 10px;
    min-width: 80px;
    display: inline-flex;
    font-size: 14px;
    margin-top: 5px;
    text-decoration: none;
}

.data-table .add-btn.btn-icon {
    min-width: 40px;
    height: 40px;
    border: 0;
}

.data-table .add-btn.btn-icon i {
    opacity: 1;
    font-size: 18px;
}

.data-table .dropdown-menu {
    min-width: 10rem;
}

.data-table .dropdown-item.active, .data-table .dropdown-item:active {
    background-color: var(--p-main-color);
}

.data-table .btn-group-vertical {
    margin-top: 5px;
}

.data-table .btn-group-vertical .add-btn {
    margin-top: 0;
}

.data-table .btn-group-vertical .add-btn+.add-btn {
    margin: 5px 0 0 0 !important;
}

.data-table th.wrap {
    white-space: normal;
}

.data-table th {
    padding: 10px;
    border-bottom: 1px solid var(--gray-300);
    /* text-align: center; */
    background-color: var(--p-main-color);
    color: #fff;
    font-size: 16px;
    white-space: nowrap;
    font-weight: 400;
}

.data-table.text-left th {
    text-align: left;
}

.data-table.card-table th {
    min-width: 100px;
}

.data-table tbody tr {
    /* border: 1px solid var(--gray-300); */
    position: relative;
}

.data-table tr td {
    padding: 10px;
    border-bottom: 1px solid var(--gray-300);
    vertical-align: middle;
    color: var(--p-font-color);
}

.data-table tr td .rwd-state {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.data-table td h3 {
    margin: 0;
    line-height: 100%;
}

body table.data-table {
    border-collapse: collapse;
}

.data-table thead {
    border: 1px solid var(--gray-300);
}

.data-table tfoot {
    border-top: none;
    border-top: 1px solid var(--gray-300);
}

.data-table .first.odd,
.box-account .data-table .odd {
    background: none;
}

.data-table.address-table, .data-table.return-table {
    text-align: left;
}

.data-table.address-table .addr {
    position: relative;
    padding: 12px;
}

.data-table.address-table .rwd-action {
    width: 30%;
}

.data-table.address-table td.addr label {
    padding: 17px 8px;
    justify-content: flex-start;
}

.data-table.address-table td.addr label input[type=radio].ace.input-lg+.lbl::before {
    top: -12px;
}

.data-table.address-table td.addr ul {
    margin-left: 35px;
    text-align: left;
}

.data-table.address-table td.addr li,
.giftlist .item li {
    font-size: 16px;
    font-weight: 300;
    color: var(--p-font-color);
}

.data-table.address-table td.addr li.name,
.giftlist .item li.name {
    font-size: 16px;
    font-weight: 400;
    color: #000;
    display: flex;
    align-items: baseline;
}

.data-table.address-table td.addr li.name span.tag,
.giftlist .item li .tag {
    font-size: 13px;
    font-weight: 300;
    color: #000;
    padding: 1px 5px;
    border-radius: 5px;
    margin-left: 5px;
    background-color: var(--p-font-color);
    color: #fff;
}

.data-table.return-table label {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
}

.data-table.return-table select {
    border: 1px solid #e3e3e3;
    padding: 0 10px;
}

.data-table.return-table label select {
    display: block;
    margin-left: 30px;
    width: auto;
    line-height: 40px;
    height: 40px;
    padding: 5px;
}

.data-table.return-table label span {
    display: block;
    margin-left: 30px;
}

.data-table.return-table select,
.data-table.return-table textarea {
    font-size: 15px;
}

.campaign-orders {
    list-style: none;
    margin: 0;
    padding: 0;
}

.campaign-orders li {
    display: flex;
}

.campaign-orders li small {
    font-size: 14px;
    color: var(--gray-600);
    width: 75px;
}

.campaign-orders li span {
    width: calc(100% - 75px);
}

@media(max-width: 767px) {
    .campaign-orders li {
        padding: 4px 0;
    }

    .campaign-orders li small {
        content: attr(data-th) " :";
        padding-right: 16px;
        font-weight: 300;
        font-size: 15px;
        width: 85px;
        white-space: nowrap;
        color: var(--p-font-color);
    }

    .rwd-table td:has(.campaign-orders):before {
        display: none;
    }
}

/**我的地址**/

.giftlist {
    margin-top: 10px;
}

.giftlist>.row {
    margin-right: -10px;
    margin-left: -10px;
}

.giftlist>.row>div {
    padding-right: 10px;
    padding-left: 10px;
}

.giftlist .item {
    border: 1px solid #eaeaea;
    padding: 20px;
    overflow: hidden;
    margin-bottom: 20px;
}

.giftlist .item .add-btn {
    min-width: 50%;

}

.giftlist .item ul {
    font-size: 16px;
    line-height: 25px;
    color: var(--gray-900);
    max-height: 100px;
    margin-bottom: 1rem;
}

.giftlist .actions {
    display: flex;
    align-items: center;
}

.giftlist .item.add {
    height: calc(100% - 20px);
}

.giftlist .item.add a {
    height: calc(100% - 20px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

.giftlist .item.add i {
    display: block;
    font-size: 25px;
    margin-bottom: 5px;
}

.giftlist .actions a.close,
.favoritelist a.close {
    background: url(../images/icon/icon-close.svg) no-repeat center #ced1d6;
    background-size: 35px;
    width: 35px;
    height: 35px;
    padding: 0;
    opacity: 1;
    position: absolute;
    right: 15px;
    top: 0;
    z-index: 1;
}

.favoritelist a.close {
    position: inherit;
}

.favoritelist .product-list .product-thumb .button-group {
    justify-content: space-evenly;
    width: 100%;
}

.favoritelist .product-list .product-thumb .button-group button {
    flex: 1;
    line-height: 35px;
}

.category-block .product-list .product-thumb {
    width: auto !important;
}

.product-list .product-thumb .caption {
    width: 100%;
}

@media only screen and (max-width: 767px) {
    .data-table.address-table .rwd-action {
        width: 10%;
    }

    .data-table.address-table .rwd-action .add-btn+.add-btn {
        margin: 5px 0 0 0 !important;
    }

    .data-table .btn-group-vertical {
        margin-top: 0;
    }

    .data-table.rwd-table tr td.order-state {
        padding-top: 0 !important;
    }
}

@media only screen and (max-width: 575px) {
    .data-table.address-table td.addr li {
        font-size: 15px;
    }

    .member-page .form-actions .order-btn {
        width: 100%;
    }

    .giftlist .item {
        margin-bottom: 1rem;
    }

    .giftlist .item .add-btn {
        min-width: 120px;
    }

    .giftlist .item.add {
        height: 160px;
    }

    .member-page .third-party p {
        margin: 0 0.5rem;
    }

    .member-page .btn {
        min-width: fit-content;
        padding: 10px 20px;
    }
}

.coupon-list .item {
    display: flex;
    align-items: center;
    border: 1px solid var(--gray-300);
    padding: 20px;
    margin-bottom: -1px;
    position: relative;
}

.coupon-list .item.used::before,
.coupon-list .item.expired::before {
    content: "";
    position: absolute;
    /* top: 0;
    left: 0; */
    width: calc(100% - 40px);
    height: calc(100% - 40px);
    background-color: rgb(255 255 255 / 50%);
    background-image: url(../images/icon/used.png);
    background-size: 100px;
    background-position: 50px center;
    background-position: right center;
    background-repeat: no-repeat;
}

.coupon-list .item.expired::before {
    background-image: url(../images/icon/expired.png);
}

.coupon-txt .item li.inline {
    margin-right: 5px;
    display: inline-block;
}

.coupon-list .item .coupon-value {
    width: 200px;
    height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #eff7f7;
    margin-right: 1rem;
}

.coupon-list .item .coupon-value span {
    color: #999;
}

.coupon-list .item .coupon-value h6 {
    font-size: 2.5rem;
    color: var(--p-main-color);
    display: flex;
    align-items: center;
}

.coupon-list .item .coupon-value h6 strong {
    font-weight: bolder;
    font-size: 120%;
}

.coupon-list .item .coupon-value h6 small {
    font-size: 70%;
    margin: 0 3px;
}

.coupon-list .item .coupon-txt li {
    margin-bottom: 5px;
    font-size: 16px;
}

.coupon-list .item .coupon-txt li.inline {
    width: fit-content;
    display: inline-block;
}

.coupon-list .item .coupon-txt li.inline+li.inline {
    margin-left: 1rem;
}

.coupon-list .item .coupon-txt span {
    color: #b0b0b0;
    margin-right: 0.5rem;
    font-size: 90%;
}

.coupon-list .item .coupon-txt strong {
    font-weight: 600;
    color: var(--p-main-color);
}

@media only screen and (max-width: 767px) {
    .coupon-list .item {
        align-items: flex-start;
    }

    .coupon-list .item .coupon-txt li.inline {
        width: 100%;
        display: block;
        margin-left: 0 !important;
    }

    .coupon-list .item .coupon-value {
        width: 130px;
        height: 130px;
    }

    .coupon-list .item.used::before, .coupon-list .item.expired::before {
        background-position: center center;
    }
}

@media only screen and (max-width: 575px) {
    .coupon-list .item {
        padding: 15px;
        margin-top: 1rem;
        justify-content: space-between;
    }

    .coupon-list .item.used::before, .coupon-list .item.expired::before {
        width: calc(100% - 30px);
        height: calc(100% - 30px);
    }

    .coupon-list .item .coupon-txt li {
        margin-bottom: 2px;
        font-size: 15px;
    }

    .coupon-list .item .coupon-value {
        width: 80px;
        height: 80px;
        margin-right: 0;
    }

    .coupon-list .item .coupon-txt {
        width: calc(100% - 90px);
    }

    .coupon-list .item .coupon-value h6 {
        font-size: 1.5rem;
    }

    .coupon-list .item .coupon-value h6 small {
        font-size: 90%;
    }
}

.a-center input.checkbox {
    float: none;
}

label.required em {
    font-weight: normal;
    padding: 0 5px 0 0;
    vertical-align: middle;
    color: #E1464D;
}

.page-title h1 {
    font-size: 25px;
    margin-bottom: 20px;
    text-align: center;
    border-bottom: 1px solid #eee;
    padding-bottom: 13px;
    line-height: 25px;
}

.page-title h1:after {
    position: absolute;
    left: 50%;
    margin-left: -18px;
    margin-top: 37px;
    height: 3px;
    width: 36px;
    z-index: 9;
    background: #57B3DF;
    border-radius: 90px;
    content: '';
    opacity: 1;
}


.page-title h2 {
    /* border-bottom: 1px solid var(--gray-300); */
    font-size: 27px;
    /* padding-bottom: 13px; */
}

.block-title {
    margin: 10px 0px 0px 0px;
    border-bottom: 1px solid var(--gray-300);
    padding-bottom: 8px;
    position: relative;
    text-align: center;
}

.block-title:before {
    content: "";
    float: right;
    position: absolute;
    margin-top: 26px;
    width: 30px;
    z-index: 10;
    height: 2px;
    margin-left: 15px;
}

.member-page .btn-group {
    margin-bottom: 3px;
}

.member-page .phone-btn .add-btn {
    padding: 5px 20px;
    margin: 5px 2px 0 0;
}

.member-page p .add-btn {
    margin: 0;
}

.member-page .faq-content-area {
    margin-top: 30px;
}

.member-page .faq-content-area .accordion .acc-btn {
    background: none;
    border-bottom: 1px solid var(--gray-300);
    color: #37333D;
    margin-bottom: 20px;
}

.member-page .faq-content-area .accordion .acc-btn .toggle-icon {
    left: 0px;
    top: 18px;
    color: #000;
}

.member-page .faq-content-area .accordion-box .accordion .acc-content {
    background: none;
    padding: 0;
}

.member-page .form-actions {
    margin-top: 20px;
}

.member-page .shop-cart-table .cart_table_title {
    background-color: var(--p-main-color);
    color: #fff;
}

.member-page .campaign .shop-cart-table .cart_table_title {
    background-color: #eff7f7;
    color: var(--p-font-color);
}

.member-page .shop-cart-table.shop-message th {
    border: 1px solid var(--gray-300);
}

.member-page .shop-cart-table td {
    color: var(--gray-900);
    /* border: 1px solid var(--gray-300); */
}

.member-page .shop-cart-table td .pro-item {
    padding-right: 0;
}

.shop-cart-table .message-type {
    width: 20%;
}

.shop-cart-table .message-type span {
    font-size: 14px;
    font-weight: 300;
}

.shop-cart-table .message-info {
    width: 60%;
}

.shop-cart-table td.message-type, .shop-cart-table td.message-info {
    text-align: left;
}

.shop-cart-table td.message-time {
    width: 20%;
    font-size: 14px;
}

.shop-cart-table.shop-message td {
    border-right: 1px solid var(--gray-300);
    border-left: 1px solid var(--gray-300);
}

.faq-btn {
    display: block;
    padding: 15px 0;
    color: #fff;
    text-align: center;
}

.faq .togglet i {
    font-size: 20px;
    padding-right: 5px;
    color: #88957A;
}

.shop-cart-table.shop-message .bg2 td, .shop-cart-table.shop-message .bg2 span {
    background-color: var(--gray-100);
    color: var(--gray-900) !important;

}

.notice {
    text-align: center;
    line-height: 1.5;
    margin-bottom: 1rem;
    font-size: 16px;
    color: var(--p-focus-color);
    width: 100%;
}

.form-row .notice {
    text-align: left;
    margin-bottom: 0;
    margin-top: 0.5rem;
}

.form-row .notice+.notice {
    margin-top: 0;
}

.notice-regi ul, .notice-regi p {
    font-size: 19px;
    color: var(--p-main-color);
    line-height: 1.7;
    font-weight: normal;
    margin: 0;
}

.notice-regi ul {
    display: flex;
}

.notice-regi li+li {
    margin-left: 1rem;
}

@media(max-width: 576px) {
    .notice-regi ul {
        font-size: 16px !important;
    }

    .notice-regi li+li {
        margin-left: 0.5rem;
    }
}

span.forget {
    font-size: 15px;
    margin-top: 5px;
    display: block;
    padding: 0;
}

span.forget a {
    color: #555;
}

.products-mail .product_title {
    font-size: 19px;
    color: #000;
}

.products-mail .description {
    color: #555;
    font-size: 15px;
}

.products-mail li {
    margin-bottom: 10px;
}

.products-mail li.verifycode {
    display: flex;
}

.products-mail li.verifycode input {
    width: 50%;
}

.products-mail #verifycodeImg {
    height: 47px;
    margin: 0 10px;
}

.products-mail .add-btn {
    width: 100%;
    margin-top: 10px;
}

.products-mail .middle i {
    font-size: 25px;
    margin-top: 10px;
}

.input-prepend>[class*=col-] {
    padding-right: 5px;
    padding-left: 5px;
}

.input-prepend {
    margin-bottom: 15px;
}

.row.input-prepend {
    /* color:  #59493f;
	margin-bottom: 10px;
	overflow: hidden; */
    margin: 0 -5px;
    align-items: center;
}

@media (max-width: 992px) {
    .input-prepend select, .input-prepend input {
        border: 1px solid var(--p-main-color);
    }
}

.input-prepend select, .input-prepend input {
    border: 1px solid #e3e3e3;
    padding: 0 10px;
    border-radius: 6px;
}

.input-prepend input.full-input {
    width: 30%;
}

.input-prepend .btn {
    padding: 0 10px;
    background-color: var(--p-main-color);
    color: #fff;
    height: 48px;
    margin-left: 0.25rem;
    min-width: 80px;
}

.input-prepend .add-btn {
    padding: 7px 30px;
    width: auto;
}

.input-prepend .select_container {
    width: auto;
    float: left;
    margin-bottom: 0;
}

/***分享網址***/
.share-link {
    font-size: 16px;
    line-height: 25px;
    margin-bottom: 30px;
}

.share-link p {
    margin-bottom: 10px;
}

.share-link .input-prepend {
    position: relative;
}

.share-link .input-prepend input,
.share-link .input-prepend .add-btn {
    height: 55px;
    border-color: var(--p-main-color) !important;
}

.share-link .input-prepend input {
    background-color: #fff;
}

.share-link .input-prepend .btn-group {
    position: absolute;
    right: 0;
}

.share-link .input-prepend .add-btn {
    padding: 10px 15px;
    min-width: 120px;
    font-size: 16px;
    border: 0;
    border-radius: 0 6px 6px 0;
}

.modal-dialog .modal-content {
    border-radius: 0;
    border: 0;
}

.modal .modal-dialog {
    min-width: 360px;
}

.modal .modal-dialog {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    justify-content: center;
    min-height: calc(100% - 1rem);
    margin: 0 auto;
}

.modal-body {
    font-size: 16px;
    padding: 40px;
}

.modal-body h4 {
    color: var(--p-main-color);
    font-size: 28px;
    margin-bottom: 16px;
}

.modal-body {
    font-size: 16px;
    line-height: 1.5;
    text-align: left;
    margin-bottom: 0;
}

h3.modal-title {
    font-size: 21px;
    margin-top: 0;
}

.modal-body .form-block {
    border: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    box-shadow: none !important;
}

.modal-body .form-block .form-row.row {
    width: 100% !important;
}


.shopping-bag .modal-header {
    border: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 99;
}

.modal-content button.close, .increase_item.favorite_item .close {
    width: 45px;
    height: 45px;
    border-radius: 0;
    line-height: 45px;
    opacity: 1;
    font-family: "Questrial", sans-serif;
    text-align: center;
    font-size: 23px;
    text-shadow: none;
    position: inherit;
    right: 0;
    top: 0;
    color: #000;
    margin: 0;
    opacity: .8;
}

.shopping-bag .product_details h2 {
    margin-right: 30px;
    font-size: 23px;
    line-height: 28px;
    margin-bottom: 0;
}

.shopping-bag .product_details .thumb {
    width: 80px;
    float: left;
    margin-right: 10px;
}

.shopping-bag .product_details .product-price.price {
    font-size: 25px;
    background-color: transparent;
    padding: 0;
}

.shopping-bag .product_details .product-price.price .price-old {
    font-size: 16px;
}

.first-login #verifycodeImg {
    height: 45px;
    margin-right: 5px;
}

.first-login .help-inline {
    padding-left: 5px;
}

.modal-content button.close {
    right: 0;
    position: absolute;
    top: 0;
    font-size: 35px;
    z-index: 10;
}

.modal-content button.close span {
    line-height: 25px;
}





.modal.warningbox {
    z-index: 1051;
}

.warningbox.txtbox .modal-dialog {
    width: 900px;

}

.warningbox.txtbox .modal-body {
    text-align: left;
}

.warningbox.txtbox .modal-dialog .theme-title h3 {
    text-align: left;
    font-size: 25px;
    margin: 0 0 20px 0;
    border-bottom: 1px solid #e7e7e7;
    padding-bottom: 10px;
}

.warningbox h4 {
    text-align: center;
    padding: 0;

}

.warningbox .modal-footer {
    text-align: center;
    margin: 0;
    border: 0;
    padding: 0 0 15px 0;
}

.warningbox .modal-footer .add-btn {
    margin: 0;
}

.warningbox .modal-body {
    text-align: center;
}

.warningbox .modal-header {
    padding: 10px;
}

.modal-dialog.first-login {
    width: 500px;
}

.modal-dialog .form-container {
    padding: 0px;
    background-color: transparent;
}

.modal-dialog.first-login select, .modal-dialog.first-login select.form-control:not([size]):not([multiple]), .modal-dialog.first-login .login-btn h6 span {
    background-color: #fff;
}

.modal-body .product-btn .add-btn {
    margin-bottom: 0;
}

.login-btn {
    margin-top: 1rem;
}

.login-btn .add-btn+.add-btn {
    margin-top: 1rem;
    margin-left: 0 !important;
}

.order-login {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    padding-left: 2rem;
    border-left: 1px solid #e3e3e3;
}

.login-page .sub-title {
    font-size: 32px;
    font-weight: 300;
    margin-bottom: 1.5rem;
    width: 100%;
}

/***login***/
.login-page {
    margin: auto;
    margin-top: 2rem;
    margin-bottom: 2rem;
    padding-left: 0;
    padding-right: 0;
}

.login-page.line-login {
    width: 600px;
    max-width: 100%;
}

.login-page.line-login .form-control,
.login-page.line-login .form-row .input-group-append {
    font-size: 19px;
    height: 60px !important;
}

.login-page .steps, .checkout-page .steps {
    max-width: 100%;
    width: 600px;
    margin-bottom: 1rem;
}

.login-form.form-container .form-group {
    padding: 0;
}

.login-form {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    border: 1px solid var(--gray-300);
    background-color: transparent;
    border-radius: 8px;
}

.form-row.m-b-10 {
    margin-bottom: 1rem;
}

.form-row .password .btn {
    background-color: var(--gray-100) !important;
    color: var(--gray-900) !important;
    font-size: 18px;
    min-width: auto;
    height: auto;
}

/* 
.form-row .password .form-control:hover,
.form-row .password .form-control:focus {
    background-color: var(--gray-100) !important;
    color: var(--gray-900) !important;
    border: 0;
} */


.form-row .input-group-append {
    position: absolute;
    left: 5px;
    height: 48px;
}

.form-row .input-group-append.f-right {
    left: auto;
    right: 5px;
}

.login-form .form-row .forget {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    white-space: nowrap;
}

.form-row .input-group-append .input-group-text {
    background-color: transparent;
    border: 0;
    border-radius: 0;
    color: var(--p-font-color);
    opacity: 0.8;
    padding: 0;
    font-size: 24px;
}

.form-row .input-group-append .input-group-text .feather-user {
    font-size: 27px;
    display: none;
}

.form-row .input-group-append .input-group-text.input-group-icon {
    font-size: 15px;
    padding: 0;
}

.form-row .input-group-append .input-group-text.input-group-icon i::before {
    display: none;
}

.form-row .input-group-append .input-group-text.input-group-icon i {
    width: 25px;
    height: 25px;
    background-size: 100%;
}

.form-row .input-group-append .input-group-text.input-group-icon .feather-eye {
    background-image: url(../images/icon/icon-eye.png);
}

.form-row .input-group-append .input-group-text.input-group-icon .feather-eye-off {
    background-image: url(../images/icon/icon-eye-close.png);
}

.login-form .add-btn.btn-sm {
    padding: 12px 0 !important;
    font-size: 14px;
    min-width: auto;
    height: 48px;
}

.row.login-form {
    flex-wrap: nowrap;
}

.notmember {
    margin-top: 1rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
}

.notmember .add-btn {
    background-color: var(--p-second-color) !important;
    padding: 8px;
    min-width: 100px;
    margin: 0 0 0 10px;
    font-size: 15px;
}

.login-btn h6 {
    padding: 1rem 0;
    margin: 1rem 0 0 0;
    text-align: center;
    position: relative;
    font-size: 15px;
    font-weight: normal;
    color: #555;
}

.login-btn h6::before {
    content: "";
    width: 100%;
    height: 1px;
    background-color: #e3e3e3;
    display: block;
    position: absolute;
    bottom: 23px;
}

.login-btn h6 span {
    background-color: #fff;
    position: absolute;
    width: 60px;
    left: 50%;
    margin-left: -30px;
    top: 0;
    z-index: 2;
}



/***訂單查詢***/
.order-tabs .notmember {
    justify-content: center;
}

.order-tabs .notice:not(.notice.red) {
    color: var(--gray-600);
    margin-top: 0;
    text-align: center;
    font-size: 16px;
}


@media (max-width:992px) {
    .order-login {
        flex-direction: row;
        align-items: center;
        padding: 2rem 0 0 0;
        border: 0;
    }

    .login-page .order-login .sub-title {
        margin: 0 1rem 0 0;
    }
}


@media (max-width: 767px) {
    .row.login-form {
        flex-wrap: wrap;
    }
}

@media (max-width: 575px) {
    .login-page .sub-title {
        font-size: 24px;
        margin-bottom: 1rem;
    }
}


/***加入經銷商***/
.login-form.dealer-form {
    width: 1080px;
    max-width: 100%;
}

.dealer-form .label-group {
    overflow: hidden;
    margin-bottom: 5px;
}

.label-group label {
    padding-left: 0;
    line-height: 25px;
    margin-bottom: 0;
    width: 24%;
    padding: 5px 5px 5px 0;
}

.label-group label.full {
    width: 100%;
}

.dealer-form .c-checkbox label {
    font-size: 16px;
}

.dealer-form .c-checkbox label a {
    color: #000;
}

.file-upload .item {
    border-radius: 6px;
    margin-bottom: 10px;
    margin-top: 0.5rem;
    border: 1px dashed #ccc;
    padding: 5px;
    text-align: center;
    position: relative;
}

.file-upload .item a.delete {
    position: absolute;
    top: -5px;
    right: -5px;
    border-radius: 100%;
    background-color: var(--p-main-color);
    color: #fff;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.btn-file {
    overflow: hidden;
    position: relative;
    padding: 10px 15px;
    color: #fff;
    background: var(--p-main-color);
    cursor: pointer;
}

.btn-file input[type=file] {
    position: absolute;
    top: 0;
    right: 0;
    min-width: 100%;
    min-height: 100%;
    font-size: 100px;
    text-align: right;
    opacity: 0;
    cursor: pointer;
}

.success-sale, .fail-sale {
    background-image: url(../images/success.png);
    background-repeat: no-repeat;
    background-position: top right;
    background-color: rgb(247 102 134 / 10%);
    background-size: auto 100%;
    border: rgb(247 102 134 / 10%) 1px solid;

}

.success-sale.display .number h3 {
    color: #eb5d68;
}

.fail-sale {
    background-image: url(../images/fail.png?20220110);
    background-color: #f1f1f1;
    border: #ccc 1px solid;
}

/******fix-right***/
.fix-right {
    position: fixed;
    right: 1rem;
    bottom: 7rem;
    z-index: 2;

    a {
        display: flex;
        align-items: center;
        flex-direction: column;

        img {
            width: 70px;
            border-radius: 100%;
            padding: 12px;
        }

        span {
            color: #222;
            font-weight: 500;
            text-shadow: 0 0 0.2em #fff, 0 0 0.2em #fff, 0 0 0.2em #fff, 0 0 0.2em #fff;
        }
    }

    .line img {
        background-color: #06C755;
    }

    @media only screen and (max-width: 1366px) {
        width: 75px;
    }

    @media (max-width: 767px) {
        width: 70px;
    }

    @media (max-width: 575px) {
        right: 0.5rem;
        width: 55px;
        bottom: 5rem;

        a {
            img {
                width: 55px;
                padding: 8px;
            }

            span {
                width: 55px;
                text-align: center;
                font-size: 13px;
                font-weight: normal;
                line-height: 1.2;
            }
        }
    }
}

/*** 會員等級***/
.level-block {
    background-color: var(--gray-100);
    padding: 20px;
    font-size: 16px;
    line-height: 30px;
    clear: both;
    margin: 1rem 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    border-radius: 8px;
}

.level-block li {
    margin-bottom: 10px;
}

.level-block .level {
    font-size: 19px;
    font-weight: 500;
    display: inline-block;
}

.level-block .level img {
    margin: 0 5px 0 5px;
    width: 45px;
}

.level-block .upgrade {
    background-color: #fff;
    padding: 30px;
    width: 100%;
}

.level-block .upgrade .price {
    font-size: 23px;
}

.level-block .level.level1 {
    color: #f80;
}

.level-block .level.level2 {
    color: #49d5e4;
}

.level-block .progress {
    margin: 20px 0 0 0;
    font-size: 12px;
    line-height: 30px;
    height: 30px;
    border-radius: 15px;
    width: 100%;
    display: inline-block;
    background-color: var(--gray-300);
}

.level-block .progress-bar {
    font-size: 14px;
    line-height: 30px;
    background-color: var(--p-main-color);
    box-shadow: none;
}

.level-block.qrcodebox {
    padding: 30px;
    gap: .5rem
}

.level-block.qrcodebox .qrcode {
    text-align: center;
    max-width: 200px;
    border-radius: 10px;
    overflow: hidden;
    padding: 1.5rem;
    background-color: #fff;
    border: 1px solid var(--gray-100);
}

.level-block.qrcodebox .row {
    display: block
}

.level-block.qrcodebox .row>div {
    width: 100%;
    max-width: 100%;
    display: block
}

.share-link {
    font-size: 1rem;
    line-height: 25px;
    margin-bottom: 20px
}

.share-link .form-control, .sales h5.filter select {
    border: 1px solid var(--gray-300);
    background-color: #fff !important;
}

.share-link .form-inline {
    gap: 0.5rem;
}

.share-link p {
    margin-bottom: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    line-height: 1.5;
}

.share-link p a {
    color: var(--gray-900);
}

.recommend-txt {
    font-size: 1.125rem;
    line-height: 30px;
    margin: 10px 0
}

.recommend-txt ul {
    list-style-type: disc;
    padding-left: 25px
}

.copy-link {
    padding: 2px 5px;
    border: 1px solid var(--p-main-color);
    border-radius: 4px;
    font-size: .875rem;
    margin-left: 8px;
}

.copy-link i {
    margin-right: 5px
}

.add-btn.line-share-btn {
    background-color: #06b900 !important;
    border: 1px solid #06b900 !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.qrcode-actions {
    display: flex;
    align-items: center;
    margin-top: 1rem
}

.qrcode-actions .add-btn {
    min-width: 180px;
}

@media(max-width: 575.98px) {
    .qrcode-actions .add-btn {
        min-width: calc(50% - 5px);
    }
}

.qrcode-actions i {
    margin-right: 0.25rem;
}


/* ----------------------------------------------------------------------
    空資料頁面
-------------------------------------------------------------------------*/
section.full-page.empty-page, section.full-page:has(.cart-empty) {
    padding: 6rem 0 10rem 0;
    text-align: center;
    position: relative;
    display: flex;
    align-items: center;
}

.empty-box, .cart-empty {
    text-align: center;
    padding: 0.5rem;
}

.empty-box img, .cart-empty img {
    width: 120px;
    max-width: 80%;
    margin-bottom: 1rem;
}

.full-page .empty-box .title, .full-page .cart-empty .title {
    font-size: 20px;
    letter-spacing: 0;
}

.empty-box p, .cart-empty p {
    color: var(--gray-600);
    font-weight: 300;
}

@media all and (max-width: 575px) {
    .empty-box p {
        font-size: 14px;
    }
}

.modal-footer {
    justify-content: center;
}

.service-block {
    height: 450px;
    overflow-y: auto;
}

.note {
    list-style: inherit;
    padding-left: 20px;
    margin-bottom: 0;
    font-size: 14px;
    line-height: 1.4;
}

.note li {
    margin-bottom: 0.5rem;
}

.limited-time {
    padding: 0.75rem;
    background-color: #fff;
    -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
}

.limited-txt {
    color: var(--p-focus-color);
    margin: 0 0 0.5rem 0;
    font-size: 16px !important;
    line-height: 1.2;
    font-weight: 400;
}

.coupon-table {
    text-align: left;
}

.data-table.coupon-table td span {
    display: flex;
    flex: 1;
}

.data-table.coupon-table tr td {
    padding: 20px 10px;
    font-size: 15px;
}

.data-table.coupon-table tr td a {
    display: inline-block;
    color: var(--p-main-color);
}

.contact-info {
    display: flex;
    flex-direction: column;
    border-top: 1px solid var(--gray-300);
    padding-top: 2rem;
}

.contact-info p {
    margin-bottom: 0.5rem;
}

/***配送進度***/
ul.delivery-step {
    display: flex;
    padding: 30px 5px 15px 5px;
}

.delivery-step {
    padding: 0px;
    list-style: none;
    width: 100%;
    padding: 2rem 1.25rem 1.25rem 1.25rem;
    border: 1px solid var(--gray-300);
    margin: 0.5rem 0;
    position: relative;

    @media (max-width: 575px) {
        overflow-x: scroll;
        padding: 2rem 0.75rem 0.75rem 0.75rem;
    }

    .item-info {
        font-size: 14px;
        padding-bottom: 0.5rem;
    }

    .status {
        font-size: 14px;
        position: absolute;
        right: 0;
        top: 0;
        background-color: var(--gray-300);
        padding: 4px 8px;
    }

    ul {
        display: flex;
        padding: 2rem 0 1rem 0;
        background-color: var(--gray-100);
    }

    li {
        width: 100%;
        text-align: center;

        &:last-child {
            &:before {
                max-width: 50%;
                width: 50%;
            }
        }

        &:first-child {
            &:before {
                max-width: 51%;
                left: 50%;
            }
        }

        &:before {
            display: block;
            content: "";
            width: 100%;
            height: 1px;
            font-size: 0;
            overflow: hidden;
            border-top: 2px solid #c6c6c6;
            position: relative;
            z-index: 1;
            top: -2px;
        }

        .dot {
            font-size: 13px;
            border-radius: 100%;
            background-color: #c6c6c6;
            position: relative;
            z-index: 1;
            display: inline-block;
            width: 14px;
            height: 14px;
            line-height: 48px;
            text-align: center;
            border: 3px solid #fff;
            box-shadow: 0 0 0 1px #c6c6c6;
            left: 0;
            top: -13px;
        }

        p {
            width: 100%;
            margin: 0px !important;
            position: relative;
            text-align: center;
            padding: 0 !important;
            border-bottom: 0 !important;
            white-space: nowrap;

            span {
                font-size: 14px;
                margin: 0 3px;
                color: #999;

                &:first-child {
                    display: block;
                    font-size: 15px;
                    line-height: 1.2;
                    color: var(--gray-600);
                    font-weight: 400;
                }

                @media (max-width: 575px) {
                    font-size: 12px;
                    margin: 0 2px;

                    &:first-child {
                        font-size: 14px;
                    }
                }
            }
        }

        &.selected {
            &:before {
                border-color: var(--p-main-color);
            }

            .dot {
                background: var(--p-main-color);
                box-shadow: 0 0 0 1px var(--p-main-color);
            }

            p span:first-child {
                color: var(--p-main-color);
            }
        }
    }
}


.reward-block.row, .row:has(.display) {
    margin-right: -0.5rem;
    margin-left: -0.5rem;

    >div {
        padding-right: 0.5rem;
        padding-left: 0.5rem;
        margin-bottom: 1rem;
    }
}

.reward-block {
    display: flex;
    justify-content: center;
    border-radius: 10px;
    margin-bottom: 1rem;

    @media (max-width: 575px) {
        margin-bottom: 0;

        >div {
            margin-bottom: 1rem !important;
        }
    }

    a {
        display: inline-flex;
        gap: 0.5rem;
    }

    i.fa-question-circle::before {
        font-family: 'feather' !important;
        content: "\e978";
        font-size: 22px;
    }

    .form-block {
        height: 100%;
        margin-bottom: 0 !important;
    }

}

.money-draw {
    text-align: center;
    margin-bottom: 20px;
    border-bottom: 1px solid #ededed;
    padding-bottom: 10px;

    span {
        display: block;
        margin-bottom: 10px;
    }
}

.money-draw span a:hover, .money-draw-info li a:hover {
    color: var(--p-main-color) !important;
}

.money-draw-info, .account-num {
    list-style: none;
    padding: 0;
    margin-bottom: 0;

    li {
        font-size: 16px;
        display: flex;
        margin-bottom: 10px;
        align-items: baseline;
    }
}

.money-draw-info {
    li {
        justify-content: space-between;
        background-color: var(--gray-100);
        padding: 0.75rem 1rem;
        border-radius: 8px;

        span {
            font-size: 26px;
            color: var(--p-focus-color);
        }
    }
}

.account-num li strong {
    strong {
        font-weight: normal;
        width: 85px;
    }

    span {
        color: var(--p-main-color);

    }
}

/* 會員-經銷商-下方水平功能選單 */
ul.member-menu {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 0;
    box-shadow: 0 0 20px 0 rgb(0 0 0 / 10%);

    li {
        flex: 1;
        border-right: 1px solid #eaeaea;
        border-top: 0;

        &:last-child {
            border-right: 0;
        }

        a,
        button {
            display: flex;
            flex-direction: column;
            align-items: center;
            font-size: 12px;
            padding: 8px 0;
            color: var(--p-font-color);
            border: 0;
            width: 100%;
            box-shadow: none !important;
            opacity: 0.7;

            i {
                width: 30px;
                height: 25px;
                margin-bottom: 5px;
                background-size: 100%;
                background-repeat: no-repeat;
                background-position: center;
            }
        }

        span {
            white-space: nowrap;
            font-weight: 500;
            color: var(--gray-900);
        }

        &.current {
            a {
                opacity: 1;
            }
        }
    }
}

#member-moremenu {
    position: absolute;
    min-width: 70px;
    border: 0;
    margin: 0;
    top: auto !important;
    bottom: 100%;
    padding: 0;
    border-radius: 0;
    right: 0;
    left: 90%;
    margin-left: -40px;

    li {
        border-right: 0;
    }
}

@media (max-width: 992px) {
    #member-moremenu {
        left: 85%;
    }
}

@media (max-width: 575px) {
    #member-moremenu {
        left: 90%;
    }
}

i.fa.bt-user {
    background-image: url("../images/icon/icon-bt-01.png");
}

i.fa.bt-orders {
    background-image: url("../images/icon/icon-bt-02.png");
}

i.fa.bt-coupoon {
    background-image: url("../images/icon/icon-bt-04.png");
}

i.fa.bt-link {
    background-image: url("../images/icon/icon-bt-10.png");
}

i.fa.bt-address {
    background-image: url("../images/icon/icon-bt-12.png");
}

i.fa.bt-dealer {
    background-image: url("../images/icon/icon-bt-07.jpg")
}

i.fa.bt-sales {
    background-image: url("../images/icon/icon-bt-08.jpg")
}

i.fa.bt-benefit {
    background-image: url("../images/icon/icon-bt-09.jpg")
}

i.fa.bt-link {
    background-image: url("../images/icon/icon-bt-10.jpg")
}

@media (max-width: 992px) {

    .product-detail-page .fix-right,
    .member-page .fix-right {
        bottom: 10.5rem;
    }
}


@media (max-width: 992px) {

    .block-account .block-content {
        display: none;
        margin-bottom: 2rem;
        border: 0;
        padding: 0 15px;
        margin-right: -15px;
        margin-left: -15px;
        background-color: #fff;
    }

    .block-account .title-header {
        display: none;
    }

    .block-account .block-content ul {
        list-style: none;
        /* white-space: nowrap; */
        overflow-x: scroll;
        overflow-y: hidden;
        display: flex;
        width: 100%;
    }

    .block-account .block-content>ul>li {
        display: inline-block;
        width: auto;
        text-align: center;
        margin-bottom: 0;
        position: relative;
        width: 20%;
    }

    .block-account .block-content>ul>li a {
        margin: 0px;
        padding: 10px 5px;
        border-right: 0;
        height: 100%;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .block-account .block-content>ul>li:last-child a {
        border-right: 1px solid var(--gray-300);
    }

    .shop-cart-table .product-thumbnail {
        width: 15%;
        padding: 15px 0;
    }

    /* .modal .modal-dialog {
        margin: 5% auto;
    } */
    .modal-dialog.first-login {
        width: 95%;
        /* margin: 0; */
        /* min-width: auto; */
    }

    .payment-select1 ul li span.title {
        width: 100%;
        border: 0;
    }

    .payment-select1 span.txt {
        width: 100%;
        margin: 5px 0 0 35px;
    }

    .card-img {
        margin-bottom: 30px;
    }

    .payment-select1 ul li {
        width: 33%;
        padding-right: 0;
    }

}


@media (max-width: 767px) {
    .checkout-page {
        margin-top: 0;
    }

    .full-page .title, .member-page .page-title h2 {
        font-size: 28px;
    }

    section.member-page {
        padding: 1rem 0 0 0;
        background-color: var(--gray-100);
    }

    body:has(.member-page.sales) {
        padding-bottom: 64px;
    }

    .member-page .form-container .form-block,
    .rwd-table tbody tr,
    .giftlist .item,
    .level-block,
    .coupon-list .item,
    .display,
    .filter-block {
        background-color: #fff;
        border: 0;
        -webkit-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
        -moz-box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
        box-shadow: 0 0 20px 0 rgb(0 0 0 / 5%);
        border-radius: 8px;
        padding: 1.5rem;
        margin-bottom: 1rem;
    }

    .block-account .block-content>ul>li a {
        border: 0;
        height: 60px;
        line-height: 1.2;
    }

    .block-account .block-content>ul>li:last-child a {
        border-right: 0;
    }

    .block-account .block-content>ul>li.current a, .block-account .block-content>ul>li:hover a {
        background: var(--gray-100);
        color: var(--p-main-color);
        border-radius: 6px 6px 0 0;
        border-top: 2px solid #f3f3f3;
    }

    span.forget {
        margin-top: 5px;
        display: block;
        text-align: center;
        padding: 0;
    }

    .payment-select1 ul li {
        width: 50%;
    }

    .payment-select1 ul li span.title {
        width: 100%;
        border: 0;
    }

    .payment-select1 span.txt,
    .payment-select1 ul li span.txt2 {
        font-size: 13px;
        margin-left: 0;
        display: block;
        line-height: 20px;
        padding-left: 30px;
    }

    .payment-select1 ul li span.txt2 {
        margin-left: 26px;
        margin-top: 5px;
        line-height: 18px;
    }

    .form-container .form-group.form-txt {
        padding: 10px;
        margin: 0 -15px;
    }

    .hidden-phone {
        display: none !important;
    }

    .display-phone {
        display: block !important;
    }

    .data-table .cart-detail {
        text-align: left;
    }

    .shopping-bag .modal-dialog {
        margin: 0;
        min-width: 100%;
    }

    .shopping-bag .modal-dialog .modal-content {
        border: 0;
    }

    .modal-body {
        padding: 30px;
    }

    .cart-tabs .nav-pills .nav-link {
        font-size: 16px;
    }

    .shop-cart-table td {
        padding: 15px 5px;
    }

    .form-block.product_details .product-review-tab .nav {
        display: flex;
        flex-wrap: nowrap;
    }

    .form-block.product_details .product-review-tab .nav li a {
        font-size: 14px;
        padding: 16px;
    }

    .form-block.product_details .tab-content {
        padding: 20px;
    }

    .label-group label {
        width: 35%;
    }

    .data-table tr td a {
        display: inline-block;
    }

    .data-table tr td {
        padding: 5px 10px;
    }

    .rwd-table th {
        display: none;
    }

    .data-table.rwd-table tr td {
        display: flex;
        flex-wrap: nowrap;
        border: 0;
        text-align: left;
        padding: 5px 10px !important;
        border: 0;
        align-items: baseline;
        font-size: 16px;
    }

    .data-table tr td .rwd-state {
        flex-direction: row;
        align-items: baseline;
        width: calc(100% - 85px);
        justify-content: space-between;
    }

    .data-table tr td .rwd-state .add-btn {
        margin-top: 0;
    }

    .data-table.coupon-table.coupon-title {
        color: var(--p-main-color);
        font-size: 16px;
    }

    .data-table tr td.point-info {
        position: absolute;
        top: 30px;
        right: 5px;
        font-size: 20px;
    }

    .rwd-table.coupon-table td {
        display: flex;
        flex-wrap: wrap;
    }

    .rwd-table td:before {
        content: attr(data-th) "：";
        padding-right: 16px;
        font-weight: 300;
        font-size: 15px;
        width: 85px;
        white-space: nowrap;
    }

    .rwd-table td:has(.empty-box):before {
        display: none;
    }

    .rwd-table td.product-name:before, .rwd-table td.rwd-action:before {
        display: none;
    }

    .rwd-table td.rwd-action,
    .data-table.rwd-table tr td.rwd-action {
        position: absolute;
        top: 15px;
        right: 15px;
        height: calc(100% - 55px);
    }

    .rwd-table td.rwd-action label {
        position: absolute;
        top: 0;
        right: 0;
        width: 100%;
        height: 100%;
        text-align: right;
        padding: 10px 5px 0 0;
    }

    .rwd-table.return-table td:before {
        width: auto;
        margin-bottom: 10px;
    }

    .rwd-table.return-table tr td:last-child {
        padding-left: 35px;
    }

    .rwd-table.return-table tr td:last-child:before {
        display: none;
    }

    .rwd-table.coupon-table td:before {
        width: 100px;
    }

    .rwd-table td.coupon-title:before {
        display: none;
    }

    .rwd-table tbody tr {
        margin-bottom: 0;
        display: block;
        padding: 0;
    }

    .data-table.rwd-table tbody tr {
        margin-bottom: 15px;
        padding: 12px;
        position: relative;
    }

    .form-block .data-table.rwd-table tbody tr {
        box-shadow: none;
        background-color: var(--gray-100);
        box-shadow: none;
    }

    .form-block .data-table.rwd-table tr td {
        padding: 4px 0 !important;
    }

    .data-table.rwd-table tbody tr:last-child, .data-table.rwd-table:last-child {
        margin-bottom: 0;
    }

    .rwd-table thead {
        border: 0;
    }

    .level-block .upgrade {
        padding: 15px;
    }

    .shop-cart-table.cart-table-m thead .product-quantity,
    .shop-cart-table.cart-table-m thead .product-subtotal,
    .shop-cart-table.cart-table-m thead .product-remove {
        display: none;
    }

    .cart-table-m .cart_table_title {
        display: none;
    }

    .cart-table-m .cart_table_item {
        position: relative;
        display: block;
        overflow: hidden;
        border-bottom: 1px solid #ebebeb;
        padding: 15px 0;
    }

    .shop-cart-table.cart-table-m td {
        display: flex;
        padding: 0;
        border: 0;
    }

    .shop-cart-table td .pro-item {
        width: 100%;
        align-items: flex-start;
    }

    .shop-cart-table td .pro-item .item-name{
        padding-right: 30px;
    }

    .form-block .cart-table-m .cart_table_item {
        padding: 10px 0;
    }

    .form-block .shop-cart-table.cart-table-m td {
        padding: 5px 10px;
    }

    .form-block .shop-cart-table.cart-table-m .product-subtotal {
        position: absolute;
        top: 0;
        right: 0;
        font-size: 18px;
    }

    .form-block .campaign .shop-cart-table tfoot td.product-subtotal {
        position: inherit;
    }

    .form-block .shop-cart-table td .pro-item .item-name{
        padding-right: 110px;
    }

    .form-block .campaign .item-info .qty {
        line-height: 1 !important;
        margin-top: 10px;
    }

    .item-info .price, .item-info .qty {
        display: block;
    }

    .item-info .qty {
        color: var(--gray-600);
    }

    .shop-cart-table.cart-table-m td.product-price {
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        width: 100%;
        /* position: absolute; */
        /* top: 60px; */
        /* right: 0; */
    }

    .shop-cart-table.cart-table-m .product-quantity, .shop-cart-table .product-name .product-quantity {
        float: left;
        height: 40px;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        padding: 0;
        margin-left: 75px;
        margin-left: 0;
        /* margin-top: 10px; */
        width: fit-content;
    }

    .shop-cart-table.cart-table-m .product-subtotal,
    .shop-cart-table .product-name .product-subtotal {
        float: right;
        text-align: right;
        display: block;
        line-height: 1.4;
        font-size: 16px;
        font-weight: 600;
        margin-top: 10px;
        width: fit-content;
    }

    .shop-cart-table .product-name .product-quantity {
        display: block;
        width: 60%;
        height: auto;
        padding-left: 0;
        margin-top: 15px;
    }

    .shop-cart-table .product-name .product-subtotal {
        display: block;
        width: 40%;
        line-height: 20px;
        margin-top: 15px;
    }

    .shop-cart-table .product-name .product-quantity::before, .shop-cart-table .product-name .product-subtotal::before {
        display: none;
    }

    .shop-cart-table .product-quantity .storehouse {
        margin-left: 3px;
        font-size: 13px;
    }

    .shop-cart-table.cart-table-m .product-remove {
        position: absolute;
        top: 15px;
        justify-content: center;
        font-size: 20px;
        right: 0;
        padding: 0;
    }

    .shop-cart-table.cart-table-m .product-remove a,
    .campaign-title a i {
        font-size: 19px;
    }

    .shop-cart-table.cart-table-m .product-subtotal:before,
    .shop-cart-table.cart-table-m .product-quantity:before {
        font-size: 15px;
        content: attr(data-th) " :";
        padding-right: 5px;
    }

    .shop-cart-table.cart-table-m .quantity {
        width: 160px;
    }

    .item-thumbs {
        width: 60px;
    }

    .shop-cart-table.cart-table-m .product-quantity .qty-set {
        margin: 0;
        display: block;
    }

    .shop-cart-table.cart-table-m .product-quantity input {
        padding: 5px 7px;
        height: 40px;
        border-color: #ebebeb;
    }

    .card-select ul li {
        width: 100%;
    }

    /* .shopping-bag.modal, #delivery-notice.modal {
        top: auto;
        padding-right: 0 !important;
    } */

    .shopping-bag .modal-dialog,
    #delivery-notice .modal-dialog,
    #point-cart .modal-dialog {
        margin: 0;
        min-width: 100%;
    }

    .orders_detail {
        font-size: 15px;
        border: 0;
    }

    .hidden-xs {
        display: none;
    }
}

@media all and (max-width: 767px) {

    /* .checkout-page .form-container h4, .payment-select1 h4, .member-page .form-container h4 {
        font-size: 21px;
    } */
    .form-container {
        padding: 50px 30px;
    }

    .modal-dialog.first-login .add-btn.first-buy {
        padding: 15px 35px;
        font-size: 16px;
    }

    .shop-cart-table .product-quantity {
        padding: 10px 0;
    }

    .first-login .modal-body {
        padding: 40px 20px;
        /* min-height: 100vh; */
        overflow: auto;
    }

    .member-page .form-container .form-block {
        margin-bottom: 1rem;
    }

    .block-account .block-content>ul>li.current:after {
        display: none;
    }
}

@media all and (max-width: 575px) {
    .display-phone {
        display: block;
        margin-top: 5px;
    }

    .shop-cart-table .event a {
        font-size: 14px;
    }

    .form-container {
        padding: 30px 0;
        background-color: transparent;
    }

    .form-block.product_details .tab-content {
        padding: 12px;
    }

    .checkout-page .form-container .form-block,
    .member-page .form-container .form-block,
    .payment-select1,
    .display,
    .filter-block {
        padding: 1rem 0.75rem;
    }

    select,
    select.form-control:not([size]):not([multiple]),
    .login-btn h6 span {
        background-color: #fff;
    }

    .login-form {
        border: 0;
    }

    .login-form .order-btn {
        width: 100%;
    }

    .order-btn, .add-btn {
        min-width: 150px;
        padding: 12px 24px;
    }

    .checkout-page .form-actions .order-btn {
        width: 100%;
    }

    .checkout-page .form-actions.align-right .order-btn {
        width: 48%;
    }

    .input-prepend #s_state,
    .input-prepends input {
        width: 100%;
    }

    .shop-cart-table .product-name a {
        display: inline-block;
    }

    .shop-cart-table .product-name .price {
        font-weight: normal;
    }

    .shop-cart-table .event {
        font-size: 14px;
        /* position: absolute;
        left: 0;
        bottom: 0; */
    }

    .shop-cart-table .product-name .increase {
        margin-bottom: 5px;
    }

    .shop-cart-table.cart-table-m .product-subtotal:before,
    .shop-cart-table.cart-table-m .product-quantity:before {
        display: none;
    }

    .cart-tabs .nav-pills li {
        width: 160px;
    }

    .form-block .shop-cart-table td .pro-item .item-name{
        padding-right: 75px;
    }

    .notice {
        text-align: left;
        font-size: 15px;
    }

    .form-container .form-group {
        border-bottom: 0px dotted var(--gray-300);
        margin-left: 0;
        margin-right: 0;
    }

    .checkout-page .form-container h4, .payment-select1 h4, .member-page .form-container h4 {
        font-size: 20px;
        font-weight: 500;
    }

    .block-account .block-content>ul>li {
        font-size: 15px;
        font-weight: 400;
        flex: 1;
    }

    .block-account .block-content>ul>li a {
        height: 50px;
        color: var(--p-font-color);
    }

    .fixed-button ul.button-menu li a {
        padding: 12px 0;
    }

    .fixed-button ul.button-menu li img {
        width: 25px;
        height: 25px;
    }

    .fixed-button ul.product-btn .add-btn {
        padding: 10px 0;
    }

    .fixed-button ul.button-menu li span {
        font-size: 12px;
        display: none;
    }

    .modal {
        padding-right: 0 !important;
    }

    .modal .modal-dialog {
        max-width: 100%;
        width: 95% !important;
    }

    .modal-body {
        padding: 1rem;
    }

    .shopping-bag .product_details .thumb {
        display: none;
    }

    .shopping-bag.modal {
        max-height: 100%;
        overflow-y: scroll;
    }

    .input-prepend .select_container {
        width: 100%;
        margin-bottom: 5px;
        border: 1px solid #ebebeb;
    }

    .input-prepend .add-btn {
        border: 1px solid #000;
    }

    .share-link .input-prepend .add-btn {
        padding: 10px 15px;
        min-width: auto;
        font-size: 14px;
    }

    .share-link .input-prepend input {
        padding: 10px 15px;
    }

    .level-block.qrcodebox {
        padding: 1.5rem;
    }

    .level-block.qrcodebox>.row {
        margin-right: -5px;
        margin-left: -5px;
    }

    .level-block.qrcodebox>.row>div {
        padding-right: 5px;
        padding-left: 5px;
    }

    .recommend-txt {
        font-size: 15px;
        line-height: 25px;
        margin-left: 0;
    }

    .payment-select1 ul li {
        width: 100%;
    }

    .form-row .input-group-append.d-none.d-sm-flex+input {
        padding-left: 5px;
    }

    .member-page .form-block .btndrop span {
        font-size: 16px;
    }


    section.full-page.page-404 {
        padding: 4rem 0 8rem 0;
    }

    section.full-page.page-404::before, section.full-page.page-404::after {
        height: 8rem;
        max-width: 35%;
    }

    .page-404 p {
        font-size: 16px;
        line-height: 1.3;
    }

    .page-404 .input-group {
        width: 100%;
    }
}

@media all and (max-width: 575px) {
    .label-group label {
        width: 49%;
    }
}

@media all and (max-width: 320px) {
    .form-container {
        padding: 0;
    }

    .order-btn, .btn, .add-btn {
        min-width: auto;
    }

    .modal .modal-dialog {
        min-width: inherit;
    }

    input, select, .form-control, select.form-control:not([size]):not([multiple]), .form-control[readonly] {
        font-size: 15px;
    }

    .login-btn .add-btn {
        width: calc(100% - 10px);
    }

    .order-btn {
        width: 100%;
    }

    .order-btn+.order-btn {
        margin-top: 10px;
    }

    .cart-tabs .nav-pills li {
        width: 140px;
    }

    .cart-tabs .nav-pills li+li {
        margin-left: 5px;
    }
}