/* ============================================================================
   CART PAGE MOBILE FIXES - Horizontal Layout Design
   Image on left, all content on right side
   ============================================================================ */

@media (max-width: 768px) {
    /* Hide table headers (Product, Price, Qty, Total, Actions) on mobile */
    .cart-table-grid-header {
        display: none !important;
    }

    /* Card layout for each cart row */
    .cart-table-grid {
        display: grid !important;
        grid-template-columns: 118px 1fr !important;
        grid-template-areas:
            "image info"
            "image price"
            "image qty"
            "image total"
            "image actions" !important;
        column-gap: 18px !important;
        row-gap: 14px !important;
        padding: 20px 22px !important;
        margin-bottom: 18px !important;
        border-radius: 20px !important;
        border: 1px solid rgba(255, 143, 163, 0.18) !important;
        background: linear-gradient(135deg, #ffffff 0%, #fff6fb 100%) !important;
        box-shadow: 0 18px 40px rgba(255, 143, 163, 0.16) !important;
        position: relative !important;
    overflow: hidden !important;
    isolation: isolate !important;
    }

    .cart-table-grid::after {
        content: "";
        position: absolute;
        inset: auto -50% -70% 40%;
        height: 180px;
        background: radial-gradient(circle at 30% 30%, rgba(255, 143, 163, 0.28), rgba(255, 143, 163, 0));
        opacity: 0.55;
        pointer-events: none;
        transform: rotate(8deg);
    }

    /* Product image column */
    .cart-table-grid > a:first-child {
        grid-area: image !important;
        align-self: stretch !important;
        display: block !important;
        width: 100% !important;
        max-width: 118px !important;
    }

    .cart-table-grid > a:first-child img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        border-radius: 16px !important;
        box-shadow: 0 12px 30px rgba(255, 143, 163, 0.22) !important;
    }

    /* Item details */
    .cart-table-grid > div:nth-child(2) {
        grid-area: info !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        align-self: flex-start !important;
    }

    .cart-table-grid > div:nth-child(2) h4 {
        font-size: 18px !important;
        font-weight: 700 !important;
        margin: 0 !important;
        color: #152238 !important;
        line-height: 1.35 !important;
    }

    .cart-table-grid > div:nth-child(2) h4 a {
        color: inherit !important;
        text-decoration: none !important;
    }

    .cart-table-grid > div:nth-child(2) h4 a:hover {
        color: #f06482 !important;
    }

    .cart-table-grid > div:nth-child(2) p {
        font-size: 13px !important;
        color: #6b7280 !important;
        margin: 0 !important;
        font-weight: 500 !important;
    }

    .cart-delivery-badge {
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        padding: 4px 12px !important;
        background: rgba(39, 174, 96, 0.12) !important;
        color: #1b7f3e !important;
        border-radius: 999px !important;
        font-size: 11px !important;
        font-weight: 600 !important;
        letter-spacing: 0.02em !important;
    }

    .cart-delivery-badge--included {
        background: rgba(79, 70, 229, 0.12) !important;
        color: #4338ca !important;
    }

    .cart-delivery-note {
        display: block !important;
        font-size: 11px !important;
        color: #64748b !important;
        margin-top: 6px !important;
        font-weight: 500 !important;
    }

    /* Price chip */
    .cart-table-grid > div:nth-child(3) {
        grid-area: price !important;
        align-self: flex-start !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        padding: 14px 18px !important;
        border-radius: 16px !important;
        background: rgba(255, 143, 163, 0.1) !important;
        color: #f06482 !important;
        font-size: 18px !important;
        font-weight: 700 !important;
        letter-spacing: -0.01em !important;
        box-shadow: 0 12px 28px rgba(255, 143, 163, 0.18) !important;
    }

    .cart-table-grid > div:nth-child(3)::before {
        content: "Price";
        font-size: 11px !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
        color: rgba(240, 100, 130, 0.75) !important;
    }

    /* Quantity controls */
    .cart-table-grid > div:nth-child(4) {
        grid-area: qty !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        align-self: flex-start !important;
    }

    .cart-table-grid > div:nth-child(4)::before {
        content: "Quantity";
        font-size: 11px !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
        color: #a64b64 !important;
    }

    .cart-qty-control {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        border-radius: 14px !important;
        border: 1px solid rgba(240, 100, 130, 0.25) !important;
        background: #ffffff !important;
        box-shadow: 0 8px 20px rgba(255, 143, 163, 0.16) !important;
        padding: 0 !important;
        min-width: 0 !important;
        width: 100% !important;
        max-width: 220px !important;
        height: 46px !important;
    }

    .cart-qty-control .qty-btn {
        width: 46px !important;
        min-width: 46px !important;
        height: 46px !important;
        font-size: 22px !important;
        font-weight: 500 !important;
        color: #f06482 !important;
        background: transparent !important;
        border: none !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: all 0.2s ease !important;
    }

    .cart-qty-control .qty-btn:hover {
        background: rgba(240, 100, 130, 0.12) !important;
        color: #d7265c !important;
    }

    .cart-qty-control .qty-btn:active {
        transform: scale(0.94) !important;
    }

    .cart-qty-control input[type="number"] {
        flex: 1 !important;
        border: none !important;
        text-align: center !important;
        font-size: 18px !important;
        font-weight: 700 !important;
        background: transparent !important;
        color: #1f2937 !important;
        height: 46px !important;
    }

    .cart-qty-control input[type="number"]::-webkit-inner-spin-button,
    .cart-qty-control input[type="number"]::-webkit-outer-spin-button {
        -webkit-appearance: none !important;
        margin: 0 !important;
    }

    /* Total highlight */
    .cart-table-grid > div:nth-child(5) {
        grid-area: total !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
        padding: 14px 18px !important;
        border-radius: 16px !important;
        background: rgba(255, 143, 163, 0.15) !important;
        font-size: 19px !important;
        font-weight: 700 !important;
        color: #d7265c !important;
        box-shadow: 0 14px 32px rgba(255, 143, 163, 0.2) !important;
    }

    .cart-table-grid > div:nth-child(5)::before {
        content: "Line total";
        font-size: 11px !important;
        letter-spacing: 0.08em !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
        color: rgba(215, 38, 92, 0.75) !important;
    }

    /* Action buttons */
    .cart-row-actions {
        grid-area: actions !important;
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) 52px !important;
        gap: 12px !important;
        align-items: stretch !important;
        margin-top: 6px !important;
    }

    .cart-row-actions button {
        border: none !important;
        border-radius: 14px !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        cursor: pointer !important;
        transition: transform 0.2s ease, box-shadow 0.2s ease !important;
    }

    .cart-row-actions button .btn-text {
        display: inline !important;
    }

    .cart-row-actions .cart-save-btn {
        background: linear-gradient(135deg, #e8f3ff 0%, #f5f9ff 100%) !important;
        color: #1d4ed8 !important;
        box-shadow: 0 12px 28px rgba(30, 64, 175, 0.15) !important;
    }

    .cart-row-actions .cart-wishlist-btn {
        background: linear-gradient(135deg, #fff0f5 0%, #ffe4ee 100%) !important;
        color: #ec407a !important;
        box-shadow: 0 12px 28px rgba(236, 64, 122, 0.16) !important;
    }

    .cart-row-actions .cart-remove-btn {
        width: 52px !important;
        min-width: 52px !important;
        height: 52px !important;
        border-radius: 16px !important;
        background: rgba(255, 87, 115, 0.12) !important;
        color: #d7265c !important;
        box-shadow: 0 10px 24px rgba(215, 38, 92, 0.16) !important;
        font-size: 19px !important;
    }

    .cart-row-actions button:active {
        transform: scale(0.96) !important;
    }

    .cart-row-actions button:hover {
        transform: translateY(-2px) !important;
    }

    /* Maintain breathing room below cart */
    .cart-summary-wrapper {
        padding-bottom: 96px !important;
        margin-top: 24px !important;
    }

    #cartContainer {
        padding-bottom: 120px !important;
    }
}

@media (max-width: 560px) {
    .cart-table-grid {
        grid-template-columns: 104px 1fr !important;
        padding: 18px 18px !important;
        column-gap: 16px !important;
    }

    .cart-row-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-rows: 50px !important;
    }

    .cart-row-actions .cart-remove-btn {
        width: 100% !important;
    }
}
