/**
 * Cart Page Styles - RankExpert
 * Matches checkout page design - 1280px edge-to-edge
 */

/* ========================================
 * PAGE BACKGROUND & CONTAINER
 * ======================================== */

body.woocommerce-cart,
.woocommerce-cart-page {
    background-color: #f5f5f5 !important;
}

.woocommerce-cart-page,
.site-main.woocommerce-cart-page,
main.woocommerce-cart-page,
main#main.woocommerce-cart-page,
#main.woocommerce-cart-page {
    padding: 0 !important;
    padding-top: 16px !important;
    padding-bottom: 40px !important;
    margin: 0 auto !important;
    width: 100% !important;
    max-width: 1280px !important;
    box-sizing: border-box !important;
}

.woocommerce-cart-page > *:first-child,
.woocommerce-cart-page .cart-page-header {
    margin-top: 0 !important;
}

/* Remove all container padding */
.woocommerce-cart-page .container,
.woocommerce-cart-page section .container,
.woocommerce-cart-page .cart-page-header .container,
.woocommerce-cart-page .cart-content-wrapper .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-inline: 0 !important;
    margin: 0 !important;
}

/* Sections */
.cart-page-header,
.cart-content-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* ========================================
 * BREADCRUMBS
 * ======================================== */

section.cart-page-header {
    background: #fff !important;
    margin: 0 0 16px 0 !important;
    margin-top: 0 !important;
    padding: 12px 20px !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e5e5 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.cart-breadcrumb {
    font-size: 14px !important;
    color: #86868b !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.cart-breadcrumb a {
    color: #2997ff !important;
    text-decoration: none !important;
}

.cart-breadcrumb a:hover {
    text-decoration: underline !important;
}

.cart-breadcrumb .separator {
    color: #d2d2d7 !important;
}

.cart-breadcrumb .current {
    color: #1d1d1f !important;
}

/* ========================================
 * CART LAYOUT - TWO COLUMNS
 * ======================================== */

.wc-block-cart {
    display: flex !important;
    gap: 16px !important;
    align-items: flex-start !important;
}

/* Cart Items Column */
.wc-block-cart__main {
    flex: 1 !important;
    background: #fff !important;
    border-radius: 12px !important;
    padding: 20px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e5e5 !important;
}

/* Cart Totals Column */
.wc-block-cart__sidebar {
    flex: 0 0 360px !important;
    width: 360px !important;
    position: sticky !important;
    top: 80px !important;
    background: #fff !important;
    border-radius: 12px !important;
    padding: 20px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e5e5 !important;
}

.wc-block-cart__sidebar .wc-block-components-sidebar {
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

/* ========================================
 * CART TABLE HEADER
 * ======================================== */

.wc-block-cart-items__header {
    display: none !important;
}

/* ========================================
 * RESET WOOCOMMERCE BLOCK DEFAULTS
 * ======================================== */

/* Remove default borders and lines */
.wc-block-cart .wc-block-cart__main::before,
.wc-block-cart .wc-block-cart__main::after,
.wc-block-cart-items::before,
.wc-block-cart-items::after,
.wc-block-cart-items__row::before,
.wc-block-cart-items__row::after {
    display: none !important;
    content: none !important;
}

/* Reset any table-like display */
.wc-block-cart-items,
.wc-block-cart-items__row {
    display: flex !important;
    border-collapse: separate !important;
}

/* Ensure proper flex layout for cart row */
.wc-block-cart-items__row > * {
    flex-shrink: 0 !important;
}

.wc-block-cart-items__row .wc-block-cart-item__product {
    flex: 1 1 auto !important;
    flex-shrink: 1 !important;
}

/* ========================================
 * CART ITEMS
 * ======================================== */

.wc-block-cart-items {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Remove any default WooCommerce table styling */
.wc-block-cart-items table,
.wc-block-cart-items__row td,
.wc-block-cart-items__row th {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

.wc-block-cart-items__row,
.wc-block-cart-items .wc-block-cart-items__row {
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
    padding: 20px 0 !important;
    border-top: 1px solid #e5e5e5 !important;
    border-bottom: none !important;
    margin: 0 !important;
}

.wc-block-cart-items__row:first-child,
.wc-block-cart-items .wc-block-cart-items__row:first-child {
    border-top: none !important;
    padding-top: 0 !important;
}

.wc-block-cart-items__row:last-child {
    padding-bottom: 0 !important;
}

/* Product Image */
.wc-block-cart-item__image,
.wc-block-components-product-image {
    width: 80px !important;
    min-width: 80px !important;
    max-width: 80px !important;
    height: 80px !important;
    min-height: 80px !important;
    max-height: 80px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
    background: #f5f5f7 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.wc-block-cart-item__image img,
.wc-block-components-product-image img {
    width: 80px !important;
    height: 80px !important;
    max-width: 80px !important;
    max-height: 80px !important;
    object-fit: cover !important;
    border-radius: 8px !important;
}

/* Product Details */
.wc-block-cart-item__product,
.wc-block-components-product-details {
    flex: 1 !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.wc-block-cart-item__product-name,
.wc-block-components-product-name {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #1d1d1f !important;
    text-decoration: none !important;
    display: block !important;
    margin: 0 0 4px 0 !important;
    line-height: 1.3 !important;
}

.wc-block-cart-item__product-name:hover,
.wc-block-components-product-name:hover {
    color: inherit !important;
}

.wc-block-cart-item__product-metadata,
.wc-block-components-product-metadata {
    font-size: 14px !important;
    color: #1d1d1f !important;
    margin: 0 !important;
}

/* Product price under name */
.wc-block-components-product-price,
.wc-block-cart-item__prices {
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #1d1d1f !important;
    margin: 4px 0 8px 0 !important;
}

/* Quantity */
.wc-block-cart-item__quantity {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.wc-block-components-quantity-selector {
    display: flex !important;
    align-items: center !important;
    border: 1px solid #d2d2d7 !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}

.wc-block-components-quantity-selector__button {
    width: 32px !important;
    height: 32px !important;
    background: #f5f5f7 !important;
    border: none !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    color: #1d1d1f !important;
}

.wc-block-components-quantity-selector__button:hover {
    background: #e5e5e7 !important;
}

.wc-block-components-quantity-selector__input {
    width: 40px !important;
    height: 32px !important;
    text-align: center !important;
    border: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* Remove Button */
.wc-block-cart-item__remove-link {
    color: #dc2626 !important;
    font-size: 13px !important;
    text-decoration: none !important;
}

.wc-block-cart-item__remove-link:hover {
    text-decoration: underline !important;
}

/* Subtotal Price (right side) */
.wc-block-cart-item__total,
.wc-block-components-product-subtotal {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #1d1d1f !important;
    min-width: 100px !important;
    text-align: right !important;
    margin-left: auto !important;
    flex-shrink: 0 !important;
}

/* ========================================
 * CART TOTALS
 * ======================================== */

.wc-block-cart__sidebar *:not(.wc-block-components-totals-footer-item) {
    border: none !important;
    box-shadow: none !important;
}

.wc-block-cart__sidebar h2 {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #86868b !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin: 0 0 16px !important;
    padding: 0 !important;
}

.wc-block-components-totals-wrapper {
    padding: 0 !important;
    margin: 0 !important;
}

.wc-block-components-totals-item {
    display: flex !important;
    justify-content: space-between !important;
    padding: 8px 0 !important;
    margin: 0 !important;
}

.wc-block-components-totals-item__label {
    font-size: 14px !important;
    color: #86868b !important;
}

.wc-block-components-totals-item__value {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #1d1d1f !important;
}

/* Total */
.wc-block-components-totals-footer-item {
    padding: 16px 0 0 !important;
    margin-top: 8px !important;
    border: none !important;
    border-top: 1px solid #e5e5e5 !important;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #1d1d1f !important;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #1d1d1f !important;
}

/* ========================================
 * PROCEED TO CHECKOUT BUTTON
 * ======================================== */

.wc-block-cart__submit-container {
    margin-top: 20px !important;
}

.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button {
    width: 100% !important;
    background: #E07B4C !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 24px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    text-align: center !important;
    text-decoration: none !important;
    display: block !important;
}

.wc-block-cart__submit-button:hover {
    background: #c96a3e !important;
}

/* Continue Shopping Link */
.wc-block-cart__submit-container a:not(.wc-block-cart__submit-button) {
    display: block !important;
    text-align: center !important;
    margin-top: 12px !important;
    color: #0071e3 !important;
    font-size: 14px !important;
    text-decoration: none !important;
}

.wc-block-cart__submit-container a:not(.wc-block-cart__submit-button):hover {
    text-decoration: underline !important;
}

/* ========================================
 * COUPON
 * ======================================== */

.wc-block-components-totals-coupon {
    padding: 16px 0 !important;
    margin: 0 !important;
}

.wc-block-components-totals-coupon__button {
    font-size: 14px !important;
    color: #0071e3 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
    cursor: pointer !important;
}

/* ========================================
 * EMPTY CART
 * ======================================== */

.wc-block-cart--is-empty {
    text-align: center !important;
    padding: 60px 20px !important;
}

.wc-block-cart--is-empty .wc-block-cart__empty-cart__title {
    font-size: 24px !important;
    font-weight: 600 !important;
    color: #1d1d1f !important;
    margin-bottom: 12px !important;
}

.wc-block-cart--is-empty p {
    color: #86868b !important;
    margin-bottom: 24px !important;
}

.wc-block-cart--is-empty .wc-block-cart__empty-cart__start-shopping {
    display: inline-block !important;
    background: #E07B4C !important;
    color: #fff !important;
    padding: 12px 24px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

/* ========================================
 * CLASSIC CART FALLBACK
 * ======================================== */

.woocommerce-cart-form {
    background: #fff !important;
    border-radius: 12px !important;
    padding: 20px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e5e5 !important;
    margin-bottom: 16px !important;
}

.woocommerce-cart-form table {
    width: 100% !important;
    border-collapse: collapse !important;
}

.woocommerce-cart-form th {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #86868b !important;
    text-transform: uppercase !important;
    padding: 12px !important;
    border-bottom: 1px solid #e5e5e5 !important;
}

.woocommerce-cart-form td {
    padding: 16px 12px !important;
    border-bottom: 1px solid #f0f0f0 !important;
    vertical-align: middle !important;
}

.woocommerce-cart-form .product-thumbnail img {
    width: 60px !important;
    height: 60px !important;
    object-fit: cover !important;
    border-radius: 8px !important;
}

.woocommerce-cart-form .product-name a {
    color: #1d1d1f !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

.woocommerce-cart-form .product-remove a {
    color: #dc2626 !important;
    font-size: 20px !important;
    text-decoration: none !important;
}

.cart-collaterals {
    background: #fff !important;
    border-radius: 12px !important;
    padding: 20px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #e5e5e5 !important;
}

.cart_totals h2 {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #86868b !important;
    text-transform: uppercase !important;
    margin-bottom: 16px !important;
}

.cart_totals table {
    width: 100% !important;
}

.cart_totals th,
.cart_totals td {
    padding: 12px 0 !important;
}

.wc-proceed-to-checkout .checkout-button {
    width: 100% !important;
    background: #E07B4C !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 24px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    text-align: center !important;
    display: block !important;
    text-decoration: none !important;
}

.wc-proceed-to-checkout .checkout-button:hover {
    background: #c96a3e !important;
}

/* ========================================
 * RESPONSIVE
 * ======================================== */

@media (max-width: 900px) {
    .wc-block-cart {
        flex-direction: column !important;
        gap: 16px !important;
    }
    
    .wc-block-cart__main,
    .wc-block-cart__sidebar {
        flex: 1 1 100% !important;
        width: 100% !important;
    }
    
    .wc-block-cart__sidebar {
        position: static !important;
    }
}

@media (max-width: 600px) {
    .woocommerce-cart-page {
        padding-top: 12px !important;
    }
    
    section.cart-page-header {
        padding: 10px 16px !important;
        margin-bottom: 12px !important;
        border-radius: 8px !important;
    }
    
    .wc-block-cart__main,
    .wc-block-cart__sidebar {
        padding: 16px !important;
        border-radius: 8px !important;
    }
    
    .wc-block-cart-items__row {
        flex-wrap: wrap !important;
    }
    
    .wc-block-cart-item__image,
    .wc-block-components-product-image {
        width: 70px !important;
        min-width: 70px !important;
        max-width: 70px !important;
        height: 70px !important;
        min-height: 70px !important;
        max-height: 70px !important;
    }
    
    .wc-block-cart-item__image img,
    .wc-block-components-product-image img {
        width: 70px !important;
        height: 70px !important;
        max-width: 70px !important;
        max-height: 70px !important;
    }
    
    .wc-block-cart-item__total,
    .wc-block-components-product-subtotal {
        width: 100% !important;
        text-align: left !important;
        margin-top: 8px !important;
        margin-left: 0 !important;
    }
}

