/* ============================================================
   SUBLIME SWEETS — CART SIDEBAR V6
   Navy × Yellow × DM Sans
   ============================================================ */

/* === SHELL === */
.cart-sidebar {
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    width: 92% !important;
    max-width: 400px !important;
    height: 100vh !important;
    background: #ffffff !important;
    transition: right 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    z-index: 10002 !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: -4px 0 24px rgba(0,0,0,0.12) !important;
    overflow: hidden !important;
    border-left: 1px solid #e8e8e8 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

@supports (height: 100svh) {
    .cart-sidebar { height: 100svh !important; max-height: 100svh !important; }
}
@supports (height: 100dvh) {
    .cart-sidebar { height: 100dvh !important; max-height: 100dvh !important; }
}

.cart-sidebar.active { right: 0 !important; }

body.dark-mode .cart-sidebar {
    background: #1a1a1a !important;
    border-left-color: #2a2a2a !important;
    box-shadow: -4px 0 24px rgba(0,0,0,0.4) !important;
}

/* === HEADER === */
.cart-header {
    flex-shrink: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 18px 20px !important;
    background: linear-gradient(135deg, #141E30, #243B55) !important;
    border-bottom: none !important;
    position: relative !important;
}

.cart-header::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 2px !important;
    background: linear-gradient(90deg, transparent, #F8D800, #FFB300, transparent) !important;
    pointer-events: none !important;
}

.cart-title {
    font-size: 11px !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    letter-spacing: 2.5px !important;
    text-transform: uppercase !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    margin: 0 !important;
}

.cart-count-badge {
    display: inline-flex !important;
    min-width: 20px !important;
    height: 20px !important;
    padding: 0 6px !important;
    background: #F8D800 !important;
    color: #141E30 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    border-radius: 10px !important;
    align-items: center !important;
    justify-content: center !important;
    letter-spacing: 0 !important;
}

.cart-header .close-btn {
    width: 30px !important;
    height: 30px !important;
    background: rgba(255,255,255,0.10) !important;
    border: 1px solid rgba(255,255,255,0.20) !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: static !important;
    transition: all 0.2s ease !important;
    color: rgba(255,255,255,0.7) !important;
}

.cart-header .close-btn svg {
    stroke: rgba(255,255,255,0.7) !important;
    width: 14px !important;
    height: 14px !important;
}

.cart-header .close-btn:hover {
    background: rgba(248,216,0,0.18) !important;
    border-color: #F8D800 !important;
}

.cart-header .close-btn:hover svg { stroke: #F8D800 !important; }

/* === CONTENT AREA === */
.cart-content {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 14px 12px !important;
    background: #f5f5f5 !important;
}

body.dark-mode .cart-content { background: #111111 !important; }

.cart-content::-webkit-scrollbar { width: 3px !important; }
.cart-content::-webkit-scrollbar-track { background: transparent !important; }
.cart-content::-webkit-scrollbar-thumb {
    background: rgba(20,30,48,0.15) !important;
    border-radius: 2px !important;
}
body.dark-mode .cart-content::-webkit-scrollbar-thumb {
    background: rgba(248,216,0,0.15) !important;
}

/* === EMPTY STATE === */
.v6-empty-state {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 60px 20px !important;
    text-align: center !important;
}

.v6-empty-icon {
    font-size: 40px !important;
    opacity: 0.3 !important;
    margin-bottom: 14px !important;
    filter: grayscale(1) !important;
}

.v6-empty-title {
    font-size: 11px !important;
    font-weight: 800 !important;
    color: #999 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    margin-bottom: 6px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

.v6-empty-text {
    color: #bbb !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    margin-bottom: 24px !important;
}

.v6-shop-btn {
    display: inline-block !important;
    background: linear-gradient(to right, #141E30, #243B55) !important;
    color: #ffffff !important;
    padding: 11px 24px !important;
    border-radius: 10px !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    transition: all 0.25s ease !important;
    border: none !important;
    cursor: pointer !important;
}

.v6-shop-btn:hover {
    box-shadow: 0 6px 20px rgba(20,30,48,0.25) !important;
    transform: translateY(-1px) !important;
}

body.dark-mode .v6-shop-btn {
    background: linear-gradient(to right, #F8D800, #FFB300) !important;
    color: #141E30 !important;
}

/* === CART ITEM ===
   Note: structure changed — image and delete button are now
   direct siblings of .v6-cart-item (delete is no longer
   absolutely positioned on top of the image). Delete button is
   now pinned to the top-right corner of the whole card. */
.v6-cart-item {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    padding: 12px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    margin-bottom: 8px !important;
    position: relative !important;
    border: 1px solid #ebebeb !important;
    transition: box-shadow 0.2s ease !important;
    align-items: flex-start !important;
    box-sizing: border-box !important;
}

.v6-cart-item:hover {
    box-shadow: 0 3px 12px rgba(20,30,48,0.08) !important;
}

body.dark-mode .v6-cart-item {
    background: #242424 !important;
    border-color: #333 !important;
}

/* === IMAGE — fixed size, no wrapper now === */
.v6-item-img {
    width: 64px !important;
    height: 64px !important;
    min-width: 64px !important;
    max-width: 64px !important;
    flex-shrink: 0 !important;
    border-radius: 8px !important;
    object-fit: cover !important;
    display: block !important;
    border: 1px solid #e8e8e8 !important;
}

body.dark-mode .v6-item-img { border-color: #3a3a3a !important; }

/* === DELETE BUTTON — pinned top-right of the whole card === */
.v6-item-del {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    width: 22px !important;
    height: 22px !important;
    border: 1px solid #e0e0e0 !important;
    background: #ffffff !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    z-index: 2 !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.10) !important;
}

.v6-item-del:hover {
    border-color: #ef4444 !important;
    background: #fef2f2 !important;
}

.v6-item-del svg {
    stroke: #bbb !important;
    width: 9px !important;
    height: 9px !important;
    transition: stroke 0.2s ease !important;
}

.v6-item-del:hover svg { stroke: #ef4444 !important; }

body.dark-mode .v6-item-del {
    background: #1a1a1a !important;
    border-color: #3a3a3a !important;
}

body.dark-mode .v6-item-del svg { stroke: #555 !important; }

body.dark-mode .v6-item-del:hover {
    border-color: #ef4444 !important;
    background: #1f0a0a !important;
}

/* === ITEM INFO — takes remaining width, leaves room for delete btn === */
.v6-item-info {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    padding-right: 26px !important;
}

.v6-item-name {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    line-height: 1.3 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

body.dark-mode .v6-item-name { color: #e0e0e0 !important; }

.v6-item-variant {
    font-size: 10px !important;
    color: #999 !important;
    letter-spacing: 0.3px !important;
    font-weight: 500 !important;
}

body.dark-mode .v6-item-variant { color: #666 !important; }

.v6-item-msg {
    font-size: 10px !important;
    color: #FFB300 !important;
    font-style: italic !important;
    font-weight: 500 !important;
}

/* Bottom row — price left, qty right */
.v6-item-bottom {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-top: 6px !important;
    gap: 8px !important;
}

/* Price row — current price + struck-through old price, side by side */
.v6-item-price-wrap {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
    min-width: 0 !important;
}

.v6-item-price {
    font-size: 15px !important;
    font-weight: 900 !important;
    color: #141E30 !important;
    letter-spacing: -0.02em !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    white-space: nowrap !important;
}

body.dark-mode .v6-item-price { color: #F8D800 !important; }

.v6-item-old-price {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #aaa !important;
    text-decoration: line-through !important;
    white-space: nowrap !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

body.dark-mode .v6-item-old-price { color: #666 !important; }

/* === QTY CONTROLS === */
.v6-qty-wrap {
    display: flex !important;
    align-items: center !important;
    border: 1.5px solid #e0e0e0 !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    background: #f8f8f8 !important;
    flex-shrink: 0 !important;
}

body.dark-mode .v6-qty-wrap {
    border-color: #3a3a3a !important;
    background: #1a1a1a !important;
}

.v6-qty-btn {
    width: 26px !important;
    height: 26px !important;
    border: none !important;
    background: transparent !important;
    color: #888 !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.15s ease, color 0.15s ease !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

.v6-qty-btn:hover {
    background: #141E30 !important;
    color: #ffffff !important;
}

body.dark-mode .v6-qty-btn { color: #888 !important; }

body.dark-mode .v6-qty-btn:hover {
    background: #F8D800 !important;
    color: #141E30 !important;
}

.v6-qty-num {
    font-size: 12px !important;
    font-weight: 800 !important;
    min-width: 22px !important;
    text-align: center !important;
    color: #1a1a1a !important;
    line-height: 26px !important;
    border-left: 1px solid #e8e8e8 !important;
    border-right: 1px solid #e8e8e8 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

body.dark-mode .v6-qty-num {
    color: #e0e0e0 !important;
    border-color: #3a3a3a !important;
}

/* === FOOTER === */
.cart-footer {
    flex-shrink: 0 !important;
    padding: 16px 20px !important;
    padding-bottom: calc(16px + env(safe-area-inset-bottom)) !important;
    background: #ffffff !important;
    border-top: 1px solid #e8e8e8 !important;
    position: relative !important;
}

.cart-footer::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 2px !important;
    background: linear-gradient(90deg, transparent, rgba(248,216,0,0.55), transparent) !important;
    pointer-events: none !important;
}

body.dark-mode .cart-footer {
    background: #1a1a1a !important;
    border-top-color: #2a2a2a !important;
}

.cart-total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    margin-bottom: 12px !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    color: #aaa !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

.cart-sidebar .cart-total span:last-child {
    font-size: 22px !important;
    font-weight: 900 !important;
    color: #141E30 !important;
    letter-spacing: -0.03em !important;
    text-transform: none !important;
    text-shadow: none !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

body.dark-mode .cart-sidebar .cart-total span:last-child {
    color: #F8D800 !important;
}

/* === CHECKOUT BUTTON === */
.cart-sidebar .checkout-btn {
    width: 100% !important;
    padding: 14px !important;
    background: linear-gradient(to right, #141E30 50%, #243B55 50%) !important;
    background-size: 200% 100% !important;
    background-position: right center !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background-position 0.36s cubic-bezier(0.4,0,0.2,1),
                box-shadow 0.25s ease !important;
    animation: none !important;
    position: relative !important;
    overflow: hidden !important;
    min-height: 48px !important;
    box-shadow: 0 4px 14px rgba(20,30,48,0.20) !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
}

.cart-sidebar .checkout-btn::before { display: none !important; }

.cart-sidebar .checkout-btn:hover {
    background-position: left center !important;
    box-shadow: 0 6px 20px rgba(20,30,48,0.30) !important;
    transform: none !important;
}

.cart-sidebar .checkout-btn:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

body.dark-mode .cart-sidebar .checkout-btn {
    background: linear-gradient(to right, #F8D800 50%, #FFB300 50%) !important;
    background-size: 200% 100% !important;
    background-position: right center !important;
    color: #141E30 !important;
    box-shadow: 0 4px 14px rgba(248,216,0,0.20) !important;
}

body.dark-mode .cart-sidebar .checkout-btn:hover {
    box-shadow: 0 6px 20px rgba(248,216,0,0.30) !important;
}

/* === MINIMUM ORDER WARNING (sidebar) ===
   Most of the visual treatment ships inline on the element
   itself (see HTML), this just covers the progress bar fill
   so it follows the theme colours. */
.min-order-bar {
    width: 100% !important;
    height: 4px !important;
    background: rgba(0,0,0,0.08) !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    margin-top: 6px !important;
}

.min-order-progress {
    height: 100% !important;
    background: var(--discount, #ef4444) !important;
    border-radius: 4px !important;
    transition: width 0.3s ease !important;
}

/* ── Theme variable overrides ── */
.cart-sidebar {
    background: var(--card) !important;
    border-left: 1px solid var(--line-md) !important;
    box-shadow: -4px 0 24px var(--s-card) !important;
    font-family: var(--font-ui) !important;
}

.cart-header {
    background: var(--gold) !important;
    border-bottom: none !important;
}

.cart-header::after {
    background: linear-gradient(90deg, 
        transparent, var(--gold-deep), transparent) !important;
}

.cart-title {
    color: #fff !important;
    font-family: var(--font-ui) !important;
}

.cart-count-badge {
    background: rgba(255,255,255,0.25) !important;
    color: #fff !important;
}

.cart-header .close-btn {
    background: rgba(255,255,255,0.12) !important;
    border-color: rgba(255,255,255,0.22) !important;
}
.cart-header .close-btn:hover {
    background: rgba(255,255,255,0.22) !important;
    border-color: rgba(255,255,255,0.5) !important;
}
.cart-header .close-btn svg { stroke: #fff !important; }

.cart-content {
    background: var(--bg) !important;
}

.cart-content::-webkit-scrollbar-thumb {
    background: var(--gold-pale) !important;
}

.v6-cart-item {
    background: var(--card) !important;
    border-color: var(--line) !important;
}

.v6-item-name {
    color: var(--text) !important;
    font-family: var(--font-ui) !important;
}

.v6-item-variant { color: var(--text-dim) !important; }

.v6-item-msg { color: var(--gold-2) !important; }

.v6-item-price {
    color: var(--text) !important;
    font-family: var(--font-ui) !important;
}

.v6-item-old-price { color: var(--text-dim) !important; }

.v6-qty-wrap {
    border-color: var(--line-md) !important;
    background: var(--surface) !important;
}

.v6-qty-btn { color: var(--text-2) !important; }

.v6-qty-btn:hover {
    background: var(--gold) !important;
    color: #fff !important;
}

.v6-qty-num {
    color: var(--text) !important;
    border-color: var(--line) !important;
    font-family: var(--font-ui) !important;
}

.v6-shop-btn {
    background: var(--gold) !important;
    color: #fff !important;
}

.v6-shop-btn:hover {
    background: var(--gold-deep) !important;
}

.cart-footer {
    background: var(--card) !important;
    border-top-color: var(--line-md) !important;
}

.cart-footer::before {
    background: linear-gradient(90deg, 
        transparent, var(--gold-glow), transparent) !important;
}

.cart-total { color: var(--text-dim) !important; }

.cart-sidebar .cart-total span:last-child {
    color: var(--text) !important;
    font-family: var(--font-ui) !important;
}

.cart-sidebar .checkout-btn {
    background-image: linear-gradient(
        to right, var(--gold-2) 50%, var(--gold) 50%) !important;
    background-size: 200% 100% !important;
    background-position: right center !important;
    color: #fff !important;
    box-shadow: 0 4px 14px var(--gold-glow) !important;
    font-family: var(--font-ui) !important;
}

.cart-sidebar .checkout-btn:hover {
    background-position: left center !important;
    box-shadow: 0 6px 20px var(--gold-glow) !important;
}

/* ── Dark mode overrides ── */
body.dark-mode .cart-sidebar {
    box-shadow: -4px 0 24px rgba(0,0,0,0.5) !important;
}

body.dark-mode .cart-header {
    background: var(--gold-deep) !important;
}

body.dark-mode .v6-item-del {
    background: var(--surface) !important;
    border-color: var(--line-md) !important;
}

body.dark-mode .cart-sidebar .cart-total span:last-child {
    color: var(--gold-2) !important;
}