/* Product Bundle Addon — Frontend CSS v2.4 */
.pbap-wrap,
.pbap-wrap * {
    box-sizing: border-box !important;
}

.pbap-wrap {
    width: 100% !important;
    margin: 20px 0 28px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 12px 35px rgba(17, 24, 39, .08) !important;
    color: #111827 !important;
    font-family: inherit !important;
}

.pbap-wrap .pbap-header {
    display: flex !important;
    justify-content: space-between !important;
    gap: 18px !important;
    align-items: center !important;
    padding: 20px 22px !important;
    background: linear-gradient(135deg, #fff 0%, #f8fafc 100%) !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.pbap-wrap .pbap-kicker {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 0 6px !important;
    color: #be123c !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
}

.pbap-wrap .pbap-header h3 {
    margin: 0 !important;
    padding: 0 !important;
    color: #111827 !important;
    font-size: 22px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
}

.pbap-wrap .pbap-header-total {
    display: none;
    min-width: 150px !important;
    padding: 10px 14px !important;
    border: 1px solid #fecdd3 !important;
    border-radius: 14px !important;
    text-align: right !important;
    background: #fff1f2 !important;
}

.pbap-wrap .pbap-header-total span {
    display: block !important;
    color: #9f1239 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
    line-height: 1.2 !important;
}

.pbap-wrap .pbap-header-total strong {
    display: block !important;
    margin-top: 4px !important;
    color: #be123c !important;
    font-size: 21px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
}

.pbap-wrap .pbap-notice {
    padding: 11px 22px !important;
    background: #fffbeb !important;
    color: #92400e !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    font-weight: 600 !important;
    border-bottom: 1px solid #fde68a !important;
}

.pbap-wrap .pbap-table {
    display: block !important;
    width: 100% !important;
}

.pbap-wrap .pbap-thead,
.pbap-wrap .pbap-row {
    display: grid !important;
    grid-template-columns: minmax(170px, 1fr) 90px 128px 110px !important;
    align-items: center !important;
    gap: 14px !important;
}

.pbap-wrap .pbap-thead {
    padding: 11px 22px !important;
    background: #f9fafb !important;
    border-bottom: 1px solid #eef2f7 !important;
}

.pbap-wrap .pbap-th {
    margin: 0 !important;
    color: #6b7280 !important;
    font-size: 11px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
}

.pbap-wrap .pbap-th-size,
.pbap-wrap .pbap-th-qty {
    text-align: center !important;
}

.pbap-wrap .pbap-th-amt {
    text-align: right !important;
}

.pbap-wrap .pbap-body {
    display: block !important;
}

.pbap-wrap .pbap-row {
    padding: 15px 22px !important;
    background: #fff !important;
    border-bottom: 1px solid #f1f5f9 !important;
}

.pbap-wrap .pbap-row:last-child {
    border-bottom: none !important;
}

.pbap-wrap .pbap-row:hover {
    background: #fffafa !important;
}

.pbap-wrap .pbap-col-name,
.pbap-wrap .pbap-col-size,
.pbap-wrap .pbap-col-qty,
.pbap-wrap .pbap-col-amt {
    margin: 0 !important;
    padding: 0 !important;
    min-width: 0 !important;
}

.pbap-wrap .pbap-label {
    display: block !important;
    margin: 0 0 5px !important;
    padding: 0 !important;
    color: #111827 !important;
    font-size: 15px !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
}

.pbap-wrap .pbap-prices {
    display: none !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.pbap-wrap .pbap-price-note {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 20px !important;
    padding: 2px 7px !important;
    border-radius: 999px !important;
    background: #f3f4f6 !important;
    color: #6b7280 !important;
    font-size: 11px !important;
    line-height: 1.3 !important;
    font-weight: 600 !important;
}

.pbap-wrap .pbap-bundle-note {
    background: #fee2e2 !important;
    color: #991b1b !important;
}

.pbap-wrap.pbap-original-mode .pbap-bundle-note {
    opacity: .55 !important;
}

.pbap-wrap .pbap-size,
.pbap-wrap .pbap-na {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 62px !important;
    min-height: 28px !important;
    padding: 5px 10px !important;
    border-radius: 999px !important;
    background: #f3f4f6 !important;
    color: #374151 !important;
    font-size: 12px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
}

.pbap-wrap .pbap-na {
    color: #9ca3af !important;
}

.pbap-wrap .pbap-col-size,
.pbap-wrap .pbap-col-qty {
    text-align: center !important;
}

.pbap-wrap .pbap-qty-ctrl {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 40px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 2px 7px rgba(17, 24, 39, .06) !important;
}

.pbap-wrap .pbap-minus,
.pbap-wrap .pbap-plus {
    -webkit-appearance: none !important;
    appearance: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 40px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    color: #be123c !important;
    font-size: 21px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    cursor: pointer !important;
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    transition: background .15s ease, color .15s ease !important;
}

.pbap-wrap .pbap-minus:hover,
.pbap-wrap .pbap-plus:hover,
.pbap-wrap .pbap-minus:focus,
.pbap-wrap .pbap-plus:focus {
    background: #be123c !important;
    color: #fff !important;
    outline: none !important;
}

.pbap-wrap .pbap-n {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 46px !important;
    min-width: 46px !important;
    height: 40px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-left: 1px solid #e5e7eb !important;
    border-right: 1px solid #e5e7eb !important;
    border-radius: 0 !important;
    background: #fff !important;
    color: #111827 !important;
    font-size: 15px !important;
    line-height: 40px !important;
    font-weight: 800 !important;
    text-align: center !important;
    box-shadow: none !important;
    outline: none !important;
    -moz-appearance: textfield !important;
}

.pbap-wrap .pbap-n::-webkit-inner-spin-button,
.pbap-wrap .pbap-n::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
    margin: 0 !important;
}

.pbap-wrap .pbap-col-amt {
    text-align: right !important;
}

.pbap-wrap .pbap-rowtotal {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #111827 !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

.pbap-wrap .pbap-foot {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    padding: 18px 22px !important;
    background: #111827 !important;
}

.pbap-wrap .pbap-cta {
    color: #fff !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
}

.pbap-wrap .pbap-grand {
    color: #fff !important;
    font-size: 28px !important;
    line-height: 1.1 !important;
    font-weight: 950 !important;
    white-space: nowrap !important;
}

@media screen and (max-width: 680px) {
    .pbap-wrap {
        border-radius: 14px !important;
        margin-top: 16px !important;
    }

    .pbap-wrap .pbap-header {
        align-items: flex-start !important;
        flex-direction: column !important;
        padding: 18px 16px !important;
    }

    .pbap-wrap .pbap-header-total {
        width: 100% !important;
        text-align: left !important;
    }

    .pbap-wrap .pbap-thead {
        display: none !important;
    }

    .pbap-wrap .pbap-row {
        grid-template-columns: 1fr auto !important;
        grid-template-areas:
            "name amount"
            "size qty" !important;
        gap: 12px !important;
        padding: 15px 16px !important;
    }

    .pbap-wrap .pbap-col-name { grid-area: name !important; }
    .pbap-wrap .pbap-col-amt  { grid-area: amount !important; }
    .pbap-wrap .pbap-col-size { grid-area: size !important; text-align: left !important; }
    .pbap-wrap .pbap-col-qty  { grid-area: qty !important; text-align: right !important; }

    .pbap-wrap .pbap-label {
        font-size: 14px !important;
    }

    .pbap-wrap .pbap-prices {
        gap: 5px !important;
    }

    .pbap-wrap .pbap-price-note {
        font-size: 10.5px !important;
        padding: 2px 6px !important;
    }

    .pbap-wrap .pbap-rowtotal {
        font-size: 14px !important;
        padding-top: 2px !important;
    }

    .pbap-wrap .pbap-qty-ctrl {
        height: 38px !important;
    }

    .pbap-wrap .pbap-minus,
    .pbap-wrap .pbap-plus {
        width: 34px !important;
        min-width: 34px !important;
        height: 38px !important;
        font-size: 20px !important;
    }

    .pbap-wrap .pbap-n {
        width: 42px !important;
        min-width: 42px !important;
        height: 38px !important;
        line-height: 38px !important;
    }

    .pbap-wrap .pbap-foot {
        padding: 16px !important;
    }

    .pbap-wrap .pbap-grand {
        font-size: 23px !important;
    }
}

/* v2.4 selectable size pricing */
.pbap-wrap .pbap-size-select {
    -webkit-appearance: none !important;
    appearance: none !important;
    min-width: 86px !important;
    min-height: 32px !important;
    padding: 5px 26px 5px 11px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 999px !important;
    background-color: #f9fafb !important;
    background-image: linear-gradient(45deg, transparent 50%, #be123c 50%), linear-gradient(135deg, #be123c 50%, transparent 50%) !important;
    background-position: calc(100% - 14px) 13px, calc(100% - 9px) 13px !important;
    background-size: 5px 5px, 5px 5px !important;
    background-repeat: no-repeat !important;
    color: #374151 !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    text-align: center !important;
    cursor: pointer !important;
    outline: none !important;
    box-shadow: none !important;
}

.pbap-wrap .pbap-size-select:hover,
.pbap-wrap .pbap-size-select:focus {
    border-color: #be123c !important;
    background-color: #fff1f2 !important;
}

@media screen and (max-width: 680px) {
    .pbap-wrap .pbap-size-select {
        min-width: 92px !important;
        text-align: left !important;
    }
}
