/* =========================================================
   VIBE CHECKOUT — Deep UI Enhancement v2.0
   Covers: header, fields, shipping, cart, coupon, variations,
   upsell, buttons, animations, performance, mobile
   ========================================================= */

/* === PERFORMANCE: GPU hints === */
#vibe-checkout-slider,
.vibe-shipping-card,
.vibe-cart-item,
.vibe-upsell-card,
.vibe-attr-pill,
.vibe-mini-cart-items,
.vibe-btn {
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

/* === 1. STICKY HEADER — always visible, compact === */
#vibe-slider-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 100001 !important;
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: blur(12px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(180%) !important;
    border: none !important;
    border-bottom: 1px solid rgba(0,0,0,0.06) !important;
    padding: 0.4rem 0.75rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0.5rem !important;
    box-shadow: 0 1px 8px rgba(0,0,0,0.04) !important;
    min-height: 0 !important;
    pointer-events: auto !important;
}

.vibe-drag-handle { display: none !important; }

.vibe-header-total {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0.6rem !important;
    background: #fff !important;
    border: 2px solid var(--vibe-primary) !important;
    padding: 0.45rem 0.85rem !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 10px rgba(79,70,229,0.12) !important;
    flex: 1 !important;
    min-width: 0 !important;
    margin: 0 !important;
    transition: box-shadow .3s ease, border-color .3s ease !important;
}

.vibe-header-total.vibe-highlight {
    box-shadow: 0 0 0 4px rgba(79,70,229,0.18) !important;
}

.vibe-header-price {
    font-size: 1.55rem !important;
    font-weight: 800 !important;
    color: var(--vibe-gray-900) !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    letter-spacing: -0.02em !important;
}

.vibe-header-cod-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.3rem !important;
    background: linear-gradient(135deg,#10B981 0%,#059669 100%) !important;
    color: #fff !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    padding: 0.35rem 0.7rem !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    box-shadow: 0 2px 6px rgba(16,185,129,0.3) !important;
    line-height: 1.2 !important;
}

.vibe-header-cod-badge .material-icons-round {
    font-size: 15px !important;
}

#vibe-close-btn {
    background: var(--vibe-gray-100) !important;
    border-radius: 50% !important;
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    box-shadow: none !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: background .2s, transform .2s !important;
    flex-shrink: 0 !important;
    position: static !important;
    margin: 0 !important;
    pointer-events: auto !important;
}

#vibe-close-btn:hover {
    background: var(--vibe-gray-200) !important;
    transform: scale(1.05) !important;
}

#vibe-close-btn .material-icons-round { font-size: 18px !important; }
#vibe-close-btn::before { display: none !important; }
.vibe-header-spacer { display: none !important; }

/* === 2. SLIDER — compact top === */
#vibe-checkout-form { padding-top: 0.35rem !important; }

#vibe-slider-content {
    -webkit-overflow-scrolling: touch !important;
    scroll-behavior: smooth !important;
}

/* === 3. FORM FIELDS — inline icon+label === */
.vibe-form-group label {
    right: 3rem !important;
    transition: all .2s cubic-bezier(.4,0,.2,1) !important;
}

.vibe-input-icon {
    position: absolute !important;
    top: 50% !important;
    right: 0.75rem !important;
    transform: translateY(-50%) !important;
    font-size: 18px !important;
    color: var(--vibe-gray-400) !important;
    background: transparent !important;
    padding: 0 !important;
    z-index: 21 !important;
    pointer-events: none !important;
    line-height: 1 !important;
    transition: all .2s cubic-bezier(.4,0,.2,1) !important;
}

/* Float state: icon moves to border, label sits beside it */
.vibe-form-group.vibe-float .vibe-input-icon,
.vibe-form-group.vibe-float-always .vibe-input-icon {
    top: 0 !important;
    transform: translateY(-50%) !important;
    right: 0.65rem !important;
    font-size: 14px !important;
    color: var(--vibe-primary) !important;
    background: #fff !important;
    padding: 0 3px !important;
    z-index: 22 !important;
}

.vibe-form-group.vibe-float label,
.vibe-form-group.vibe-float-always label {
    top: -0.65rem !important;
    transform: translateY(0) !important;
    right: calc(0.65rem + 22px) !important;
    font-size: 0.72rem !important;
    line-height: 1 !important;
    background: #fff !important;
    padding: 0 4px !important;
    z-index: 20 !important;
    color: var(--vibe-primary) !important;
    font-weight: 600 !important;
    height: auto !important;
    width: auto !important;
    background-color: #ffffff !important;
}

.vibe-input:not(:focus)::placeholder { color: transparent !important; }

.vibe-input:focus {
    border-color: var(--vibe-primary) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,0.08) !important;
    outline: none !important;
}

.vibe-input.vibe-valid { border-color: var(--vibe-success) !important; }

.vibe-form-group:has(.vibe-input.vibe-valid) .vibe-input-icon,
.vibe-input.vibe-valid ~ .vibe-input-icon,
.vibe-input.vibe-valid + .vibe-input-icon {
    color: var(--vibe-success) !important;
}

select.vibe-input.vibe-valid {
    background-image: url('data:image/svg+xml,%3csvg xmlns=\'http://www.w3.org/2000/svg\' fill=\'none\' viewBox=\'0 0 20 20\'%3e%3cpath stroke=\'%236b7280\' stroke-linecap=\'round\' stroke-linejoin=\'round\' stroke-width=\'1.5\' d=\'M6 8l4 4 4-4\'/%3e%3c/svg%3e') !important;
    background-position: left 0.5rem center !important;
    padding-left: 2.5rem !important;
}

.vibe-input { line-height: 1.5 !important; min-height: 44px !important; }
select.vibe-input { padding-top: 0.65rem !important; padding-bottom: 0.65rem !important; }
.vibe-grid { gap: 0.4rem !important; }

/* === 4. USER INFO CARD === */
.vibe-user-info-card {
    background: linear-gradient(135deg,rgba(79,70,229,0.04),rgba(79,70,229,0.02)) !important;
    border: 1.5px solid rgba(79,70,229,0.15) !important;
    border-radius: var(--vibe-radius) !important;
    padding: 0.5rem 0.75rem !important;
}

.vibe-user-info-card .vibe-card-icon { color: var(--vibe-success) !important; font-size: 18px !important; }
.vibe-user-info-card .vibe-card-name { font-weight: 600 !important; font-size: 0.85rem !important; }
.vibe-user-info-card .vibe-card-location { font-size: 0.72rem !important; color: var(--vibe-gray-400) !important; }
.vibe-edit-user-info { background: transparent !important; border: none !important; color: var(--vibe-primary) !important; }
.vibe-edit-user-info:hover { transform: scale(1.15) !important; }

/* === 5. PRODUCT CARD === */
.vibe-product-card {
    background: #fff !important;
    border: 1px solid var(--vibe-input-border) !important;
    border-radius: var(--vibe-radius) !important;
    padding: 0.5rem !important;
    gap: 0.65rem !important;
    box-shadow: var(--vibe-shadow-card) !important;
}

.vibe-product-image { border-radius: 8px !important; overflow: hidden !important; }
.vibe-product-title { font-weight: 600 !important; line-height: 1.25 !important; }
.vibe-product-price { color: var(--vibe-primary) !important; font-weight: 700 !important; }

/* === 6. QUANTITY SELECTOR === */
.vibe-quantity-selector {
    display: flex !important;
    align-items: center !important;
    border: 1.5px solid var(--vibe-input-border) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: var(--vibe-gray-50) !important;
    height: 32px !important;
    flex-shrink: 0 !important;
}

.vibe-quantity-selector .vibe-qty-btn {
    background: transparent !important;
    border: none !important;
    width: 28px !important;
    height: 100% !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--vibe-gray-900) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .15s !important;
}

.vibe-quantity-selector .vibe-qty-btn:active { background: var(--vibe-gray-200) !important; }

.vibe-quantity-selector .vibe-qty-input {
    width: 28px !important;
    text-align: center !important;
    border: none !important;
    background: transparent !important;
    font-weight: 700 !important;
    font-size: 0.85rem !important;
    -moz-appearance: textfield !important;
    padding: 0 !important;
}

.vibe-quantity-selector .vibe-qty-input::-webkit-inner-spin-button,
.vibe-quantity-selector .vibe-qty-input::-webkit-outer-spin-button {
    -webkit-appearance: none !important;
}

.vibe-qty-max-reached { animation: vibeMaxPulse .4s ease !important; }
@keyframes vibeMaxPulse {
    0%,100% { box-shadow: none; }
    50% { box-shadow: 0 0 0 3px rgba(239,68,68,0.2); }
}

/* === 7. VARIATIONS — round swatches + refined pills === */
.vibe-color-pills .vibe-attr-pill.vibe-color-swatch {
    width: var(--vibe-swatch-size,28px) !important;
    height: var(--vibe-swatch-size,28px) !important;
    min-width: var(--vibe-swatch-size,28px) !important;
    padding: 0 !important;
    border-radius: 50% !important;
    aspect-ratio: 1/1 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    background: var(--swatch-color,#ccc) !important;
    font-size: 0 !important;
    border: 2.5px solid var(--vibe-gray-200) !important;
    transition: all .2s ease !important;
}

.vibe-color-pills .vibe-attr-pill.vibe-color-swatch:hover {
    border-color: var(--vibe-primary) !important;
    transform: scale(1.12) !important;
}

.vibe-color-pills .vibe-attr-pill.vibe-color-swatch.active {
    border-color: var(--vibe-primary) !important;
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--vibe-primary) !important;
    transform: scale(1.05) !important;
}

.vibe-attr-pill {
    padding: 4px 12px !important;
    border: 1.5px solid var(--vibe-gray-200) !important;
    border-radius: 50px !important;
    background: #fff !important;
    font-size: 0.72rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all .15s ease !important;
}

.vibe-attr-pill:hover {
    border-color: var(--vibe-primary) !important;
    color: var(--vibe-primary) !important;
    background: rgba(79,70,229,0.03) !important;
}

.vibe-attr-pill.active {
    background: var(--vibe-primary) !important;
    border-color: var(--vibe-primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(79,70,229,0.25) !important;
}

.vibe-attr-pill.vibe-pill-disabled {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
    text-decoration: line-through !important;
}

.vibe-var-main-img { border-radius: 10px !important; transition: opacity .25s ease !important; }

/* === 8. SHIPPING CARDS === */
.vibe-shipping-methods { transition: opacity .2s ease !important; }
.vibe-shipping-methods.vibe-loading { opacity: 0.5 !important; pointer-events: none !important; }

.vibe-shipping-card {
    border: 1.5px solid var(--vibe-input-border) !important;
    border-radius: var(--vibe-radius) !important;
    background: #fff !important;
    cursor: pointer !important;
    transition: all .2s cubic-bezier(.4,0,.2,1) !important;
    box-shadow: var(--vibe-shadow-card) !important;
}

.vibe-shipping-card:hover {
    border-color: var(--vibe-primary) !important;
    box-shadow: 0 4px 14px rgba(79,70,229,0.1) !important;
    transform: translateY(-1px) !important;
}

.vibe-shipping-card.selected {
    border-color: var(--vibe-primary) !important;
    background: rgba(79,70,229,0.03) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,0.08) !important;
}

.vibe-shipping-card.selected .vibe-ship-icon {
    background: var(--vibe-primary) !important;
    color: #fff !important;
    transform: scale(1.05) !important;
}

.vibe-ship-icon { transition: all .2s ease !important; }
.vibe-ship-price { font-weight: 700 !important; color: var(--vibe-primary) !important; }
.vibe-ship-provider { font-size: 0.6rem !important; color: var(--vibe-gray-400) !important; }

.vibe-ship-free-badge {
    background: linear-gradient(135deg,#10B981,#059669) !important;
    color: #fff !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    padding: 0.15rem 0.5rem !important;
    border-radius: 999px !important;
}

/* === 9. MINI-CART === */
.vibe-mini-cart {
    background: var(--vibe-gray-50) !important;
    border: 1px solid var(--vibe-input-border) !important;
    border-radius: var(--vibe-radius) !important;
    margin-bottom: 0.6rem !important;
    overflow: hidden !important;
    box-shadow: var(--vibe-shadow-card) !important;
}

.vibe-mini-cart-header {
    padding: 0.55rem 0.75rem !important;
    background: #fff !important;
    cursor: pointer !important;
    transition: background .15s !important;
    gap: 0.5rem !important;
}

.vibe-mini-cart-header:hover { background: var(--vibe-gray-50) !important; }
.vibe-mini-cart-toggle { transition: transform .25s cubic-bezier(.4,0,.2,1) !important; }
.vibe-mini-cart.collapsed .vibe-mini-cart-toggle { transform: rotate(-90deg) !important; }

.vibe-mini-cart-items {
    max-height: 280px !important;
    overflow-y: auto !important;
    transition: max-height .3s cubic-bezier(.4,0,.2,1) !important;
    scrollbar-width: thin !important;
}

.vibe-mini-cart.collapsed .vibe-mini-cart-items { max-height: 0 !important; overflow: hidden !important; }

.vibe-cart-item {
    padding: 0.5rem 0.65rem !important;
    border-bottom: 1px solid var(--vibe-gray-100) !important;
    background: #fff !important;
    gap: 8px !important;
    transition: background .2s, opacity .3s, transform .3s !important;
}

.vibe-cart-item:last-child { border-bottom: none !important; }
.vibe-cart-item.removing { opacity: 0.3 !important; transform: translateX(20px) !important; pointer-events: none !important; }
.vibe-cart-item.deselected { opacity: 0.45 !important; background: var(--vibe-gray-50) !important; }
.vibe-cart-item.vibe-item-updated { animation: vibeItemPulse .6s ease !important; }

@keyframes vibeItemPulse {
    0% { background: #fff; }
    30% { background: rgba(79,70,229,0.06); }
    100% { background: #fff; }
}

.vibe-cart-item-thumb {
    width: 44px !important;
    height: 44px !important;
    border-radius: 8px !important;
    object-fit: cover !important;
    border: 1px solid var(--vibe-gray-100) !important;
    flex-shrink: 0 !important;
}

.vibe-cart-item-name { font-size: 0.82rem !important; font-weight: 500 !important; line-height: 1.25 !important; }
.vibe-cart-item-var { font-size: 0.68rem !important; color: var(--vibe-gray-400) !important; }
.vibe-cart-item-price { font-size: 0.85rem !important; font-weight: 700 !important; color: var(--vibe-primary) !important; white-space: nowrap !important; }

.vibe-cart-item-qty {
    display: flex !important;
    align-items: center !important;
    background: var(--vibe-gray-50) !important;
    border: 1px solid var(--vibe-gray-200) !important;
    border-radius: 6px !important;
    overflow: hidden !important;
}

.vibe-cart-item-qty button {
    width: 24px !important;
    height: 24px !important;
    background: transparent !important;
    border: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--vibe-gray-900) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .15s !important;
}

.vibe-cart-item-qty button:active { background: var(--vibe-gray-200) !important; }

.vibe-cart-item-qty input {
    width: 24px !important;
    text-align: center !important;
    border: none !important;
    background: transparent !important;
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    padding: 0 !important;
    -moz-appearance: textfield !important;
}

.vibe-cart-item-qty input::-webkit-inner-spin-button,
.vibe-cart-item-qty input::-webkit-outer-spin-button { -webkit-appearance: none !important; }

.vibe-cart-item-remove-text {
    background: transparent !important;
    border: none !important;
    color: var(--vibe-gray-300) !important;
    cursor: pointer !important;
    padding: 2px !important;
    transition: color .2s !important;
    display: flex !important;
    align-items: center !important;
}

.vibe-cart-item-remove-text:hover { color: var(--vibe-danger) !important; }
.vibe-cart-item-remove-text .material-icons-round { font-size: 18px !important; }
.vibe-cart-item-checkbox { accent-color: var(--vibe-primary) !important; }

/* === 10. COUPON TOGGLE === */
.vibe-coupon-section { margin-bottom: 0.35rem !important; }

.vibe-coupon-toggle {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.3rem !important;
    cursor: pointer !important;
    font-size: var(--vibe-input-font-size,14px) !important;
    font-weight: 600 !important;
    color: var(--vibe-primary) !important;
    transition: opacity .2s !important;
    padding: 0.2rem 0 !important;
}
.vibe-coupon-toggle .vibe-coupon-chevron {
    font-size: 16px !important;
    transition: transform .3s ease !important;
    margin-inline-start: 0.15rem !important;
}
.vibe-coupon-toggle.open .vibe-coupon-chevron {
    transform: rotate(180deg) !important;
}

.vibe-coupon-toggle:hover { opacity: 0.8 !important; }
.vibe-coupon-toggle svg { width: 15px !important; height: 15px !important; flex-shrink: 0 !important; }

.vibe-shipping-coupon-row .vibe-coupon-toggle {
    font-size: var(--vibe-input-font-size,14px) !important;
    color: var(--vibe-gray-600) !important;
    font-weight: 500 !important;
}

.vibe-shipping-coupon-row .vibe-coupon-toggle:hover { color: var(--vibe-primary) !important; }
.vibe-shipping-coupon-row .vibe-coupon-toggle svg { width: 14px !important; height: 14px !important; }

/* Coupon form: NO display override — let jQuery slideToggle control visibility */
.vibe-coupon-form {
    gap: 0.5rem !important;
    margin-top: 0.4rem !important;
    /* display is controlled by JS: hidden by default, flex when open */
}

.vibe-coupon-form input {
    flex: 1 !important;
    border: 1.5px solid var(--vibe-input-border) !important;
    border-radius: 8px !important;
    padding: 0.4rem 0.65rem !important;
    font-size: 0.85rem !important;
    transition: border-color .2s !important;
}

.vibe-coupon-form input:focus { border-color: var(--vibe-primary) !important; outline: none !important; }

.vibe-coupon-form button {
    background: var(--vibe-primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 0.4rem 0.75rem !important;
    font-weight: 600 !important;
    font-size: 0.8rem !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

/* === 11. DELIVERY NOTE === */
.vibe-toggle-note {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.25rem !important;
    font-size: 0.8rem !important;
    color: var(--vibe-primary) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    border: 1.5px dashed var(--vibe-gray-200) !important;
    padding: 0.35rem 0.75rem !important;
    border-radius: 8px !important;
    width: 100% !important;
    justify-content: center !important;
    transition: border-color .2s, background .2s !important;
}

.vibe-toggle-note:hover { border-color: var(--vibe-primary) !important; background: rgba(79,70,229,0.02) !important; }
.vibe-toggle-note .material-icons-round { font-size: 16px !important; }

/* === 12. FREE SHIPPING BAR === */
.vibe-free-shipping-bar {
    background: linear-gradient(135deg,rgba(16,185,129,0.06),rgba(16,185,129,0.02)) !important;
    border: 1px solid rgba(16,185,129,0.15) !important;
    border-radius: var(--vibe-radius) !important;
    padding: 0.4rem 0.65rem !important;
    margin-bottom: 0.5rem !important;
}

.vibe-fs-msg { font-size: 0.75rem !important; font-weight: 600 !important; color: #065F46 !important; }

.vibe-progress-track {
    height: 4px !important;
    background: rgba(16,185,129,0.15) !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    margin-top: 0.3rem !important;
}

.vibe-progress-fill {
    height: 100% !important;
    background: linear-gradient(90deg,#10B981,#059669) !important;
    border-radius: 999px !important;
    transition: width .5s cubic-bezier(.4,0,.2,1) !important;
}

/* === 13. UPSELL CARDS === */
.vibe-upsell-section { margin-top: 0.35rem !important; padding-top: 0.15rem !important; border-top: none !important; }
.vibe-upsell-header { font-size: 0.75rem !important; font-weight: 600 !important; margin-bottom: 0.3rem !important; color: var(--vibe-gray-600) !important; }

.vibe-upsell-card {
    border: 1px solid var(--vibe-gray-200) !important;
    border-radius: 10px !important;
    padding: 6px !important;
    transition: transform .2s ease, box-shadow .2s ease !important;
    background: #fff !important;
}

.vibe-upsell-card:hover { transform: translateY(-2px) !important; box-shadow: 0 4px 12px rgba(0,0,0,0.06) !important; }
.vibe-upsell-card-price { font-weight: 700 !important; color: var(--vibe-primary) !important; }
.vibe-upsell-add-btn { transition: transform .2s, color .2s !important; }
.vibe-upsell-add-btn:hover { transform: scale(1.15) !important; color: var(--vibe-primary) !important; }

/* === 14. SUBMIT BUTTONS === */
.vibe-submit-wrapper { padding-top: 0.35rem !important; gap: 0.4rem !important; }

#vibe-submit-btn {
    position: relative !important;
    overflow: hidden !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    padding: 0.75rem 1.5rem !important;
    transition: transform .15s ease, box-shadow .15s ease !important;
    box-shadow: 0 4px 14px rgba(79,70,229,0.3) !important;
}

#vibe-submit-btn:hover { transform: translateY(-1px) !important; box-shadow: 0 6px 20px rgba(79,70,229,0.35) !important; }
#vibe-submit-btn:active { transform: translateY(0) !important; }

.vibe-btn.loading { pointer-events: none !important; opacity: 0.75 !important; }

#vibe-submit-btn.vibe-btn-empty-cart,
#vibe-submit-btn:disabled {
    opacity: 0.45 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
    box-shadow: none !important;
    transform: none !important;
}

.vibe-btn-loader {
    width: 18px !important;
    height: 18px !important;
    border: 2px solid rgba(255,255,255,0.3) !important;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: vibeSpinSmooth .6s linear infinite !important;
}

@keyframes vibeSpinSmooth { to { transform: rotate(360deg); } }

/* === 15. PROMOTIONS === */
.vibe-first-order-banner {
    background: linear-gradient(135deg,rgba(79,70,229,0.06),rgba(139,92,246,0.04)) !important;
    border: 1px solid rgba(79,70,229,0.12) !important;
    border-radius: var(--vibe-radius) !important;
    padding: 0.45rem 0.65rem !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    text-align: center !important;
    margin-bottom: 0.5rem !important;
}

.vibe-qty-tier-indicator {
    background: linear-gradient(135deg,rgba(245,158,11,0.06),rgba(245,158,11,0.02)) !important;
    border: 1px solid rgba(245,158,11,0.15) !important;
    border-radius: var(--vibe-radius) !important;
    padding: 0.45rem 0.65rem !important;
    margin-bottom: 0.5rem !important;
}

/* === 16. SLIDER ANIMATION === */
#vibe-checkout-slider {
    transition: transform .35s cubic-bezier(.32,.72,0,1) !important;
}

@keyframes vibeFadeSlideUp {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.vibe-user-info-fields,
.vibe-single-product-container,
.vibe-shipping-methods,
.vibe-coupon-section,
.vibe-upsell-section {
    animation: vibeFadeSlideUp .3s ease-out;
}

/* === 17. SCROLLBARS === */
#vibe-slider-content::-webkit-scrollbar,
.vibe-mini-cart-items::-webkit-scrollbar { width: 3px !important; }

#vibe-slider-content::-webkit-scrollbar-thumb,
.vibe-mini-cart-items::-webkit-scrollbar-thumb { background: var(--vibe-gray-200) !important; border-radius: 999px !important; }

#vibe-slider-content::-webkit-scrollbar-track,
.vibe-mini-cart-items::-webkit-scrollbar-track { background: transparent !important; }

/* === 18. MOBILE (< 480px) === */
@media (max-width: 480px) {
    #vibe-slider-header { padding: 0.35rem 0.5rem !important; }
    .vibe-header-price { font-size: 1.35rem !important; }
    .vibe-header-cod-badge { font-size: 0.75rem !important; padding: 0.3rem 0.55rem !important; }
    #vibe-close-btn { width: 28px !important; height: 28px !important; min-width: 28px !important; }
    #vibe-close-btn .material-icons-round { font-size: 16px !important; }
    .vibe-grid { gap: 0.35rem !important; }
    .vibe-form-group { margin-bottom: 0.4rem !important; }
    .vibe-cart-item { padding: 0.4rem 0.5rem !important; gap: 6px !important; }
    .vibe-cart-item-thumb { width: 38px !important; height: 38px !important; }
    .vibe-cart-item-name { font-size: 0.78rem !important; }
    .vibe-cart-item-qty button { width: 22px !important; height: 22px !important; }
    .vibe-cart-item-qty input { width: 20px !important; font-size: 0.72rem !important; }
    .vibe-attr-pill { padding: 3px 9px !important; font-size: 0.68rem !important; }
    .vibe-ship-label { font-size: 0.7rem !important; }
    .vibe-ship-price { font-size: 0.75rem !important; }
    #vibe-submit-btn { font-size: 0.92rem !important; padding: 0.65rem 1rem !important; }
    .vibe-upsell-card { padding: 5px !important; min-width: 150px !important; }
}

/* === 19. REDUCED MOTION === */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}
