/* ===================================================================
   SOS EHPAD — CART PAGE
   Prefix: cart-
   Dependencies: design-system.css (--sos-* variables)
   =================================================================== */

/* overflow-x handled globally in design-system.css */

/* --- Hide default WordPress title --- */
body.woocommerce-cart .wp-block-post-title {
    display: none !important;
}

/* --- Parent container override --- */
body.woocommerce-cart .entry-content,
body.woocommerce-cart .wp-block-post-content {
    max-width: var(--sos-max-w) !important;
    width: 100% !important;
    margin: 0 auto !important;
}
body.woocommerce-cart .wp-block-post-content > .wp-block-woocommerce-cart {
    max-width: 100% !important;
}

/* =====================================================
   STEPPER
   ===================================================== */
.cart-stepper {
    max-width: var(--sos-max-w);
    margin: 0 auto 8px;
    padding: 20px 24px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    font-family: var(--sos-font);
}
.cart-step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--sos-text-light);
    white-space: nowrap;
}
.cart-step.active {
    color: var(--sos-blue-light);
}
.cart-step.active .cart-step-num {
    background: var(--sos-blue-light);
    color: #fff;
}
.cart-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--sos-border);
    color: var(--sos-text-light);
    font-size: 0.85rem;
    font-weight: 700;
    flex-shrink: 0;
}
.cart-step-sep {
    width: 48px;
    height: 2px;
    background: var(--sos-border);
    margin: 0 12px;
    border-radius: 2px;
    flex-shrink: 0;
}

/* =====================================================
   HEADER
   ===================================================== */
.cart-header {
    max-width: var(--sos-max-w);
    margin: 0 auto 24px;
    padding: 16px 24px 20px;
    font-family: var(--sos-font);
}
.cart-header-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}
.cart-header-left {
    display: flex;
    align-items: center;
    gap: 14px;
}
.cart-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--sos-blue-light);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 5px 14px;
    border-radius: 20px;
    letter-spacing: 0.02em;
}
.cart-header h1 {
    font-size: clamp(1.4rem, 3vw, 1.8rem) !important;
    font-weight: 700 !important;
    color: var(--sos-text) !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    line-height: 1.3 !important;
}
.cart-continue-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--sos-blue-light);
    text-decoration: none;
    transition: var(--sos-transition);
}
.cart-continue-link:hover {
    color: var(--sos-blue);
    text-decoration: underline;
}
.cart-header-divider {
    height: 3px;
    background: linear-gradient(90deg, var(--sos-blue-light) 0%, var(--sos-teal) 50%, var(--sos-green) 100%);
    border-radius: 3px;
    margin-top: 16px;
}

/* =====================================================
   CART BLOCK — LAYOUT
   ===================================================== */
body.woocommerce-cart .wp-block-woocommerce-cart {
    max-width: var(--sos-max-w) !important;
    margin: 0 auto !important;
    padding: 0 24px 40px !important;
}
body.woocommerce-cart .wc-block-cart {
    max-width: 100% !important;
}
body.woocommerce-cart .wc-block-cart .wc-block-cart__main {
    flex: 1 1 65% !important;
    max-width: 65% !important;
    min-width: 0 !important;
}
body.woocommerce-cart .wc-block-cart .wc-block-cart__sidebar {
    flex: 0 0 32% !important;
    max-width: 32% !important;
    min-width: 280px !important;
}

/* =====================================================
   ITEMS TABLE
   ===================================================== */
body.woocommerce-cart .wc-block-cart-items {
    border-collapse: separate !important;
    border-spacing: 0 !important;
}
body.woocommerce-cart .wc-block-cart-items__header {
    border-bottom: 2px solid var(--sos-border) !important;
}
body.woocommerce-cart .wc-block-cart-items__header span,
body.woocommerce-cart .wc-block-cart-items__header-image {
    font-family: var(--sos-font) !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    color: var(--sos-text-light) !important;
    padding-bottom: 12px !important;
}

/* --- Product row --- */
body.woocommerce-cart .wc-block-cart-items__row {
    border-bottom: 1px solid var(--sos-border) !important;
    padding: 20px 0 !important;
    transition: background 0.2s;
}
body.woocommerce-cart .wc-block-cart-items__row:hover {
    background: rgba(59, 125, 216, 0.02);
}

/* --- Product image --- */
body.woocommerce-cart .wc-block-cart-item__image img {
    border-radius: 8px !important;
    border: 1px solid var(--sos-border) !important;
    width: 90px !important;
    height: 90px !important;
    object-fit: cover !important;
}

/* --- Product name --- */
body.woocommerce-cart .wc-block-components-product-name {
    font-family: var(--sos-font) !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: var(--sos-text) !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}
body.woocommerce-cart .wc-block-components-product-name:hover {
    color: var(--sos-blue-light) !important;
}

/* --- Product price --- */
body.woocommerce-cart .wc-block-components-product-price {
    font-family: var(--sos-font) !important;
    font-weight: 600 !important;
    color: var(--sos-navy) !important;
}
body.woocommerce-cart .wc-block-components-product-price__regular {
    text-decoration: line-through !important;
    color: var(--sos-text-light) !important;
    font-weight: 400 !important;
    font-size: 0.85rem !important;
}

/* --- Sale badge --- */
body.woocommerce-cart .wc-block-components-sale-badge {
    background: linear-gradient(135deg, #ecfdf5, #d1fae5) !important;
    color: #065f46 !important;
    border: 1px solid #a7f3d0 !important;
    border-radius: 6px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    padding: 3px 10px !important;
}

/* --- Quantity selector --- */
body.woocommerce-cart .wc-block-components-quantity-selector {
    border: 1.5px solid var(--sos-border) !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}
body.woocommerce-cart .wc-block-components-quantity-selector__button {
    background: var(--sos-bg) !important;
    color: var(--sos-text) !important;
    border: none !important;
    font-weight: 600 !important;
    transition: background 0.2s !important;
}
body.woocommerce-cart .wc-block-components-quantity-selector__button:hover {
    background: var(--sos-border) !important;
}
body.woocommerce-cart .wc-block-components-quantity-selector__input {
    font-family: var(--sos-font) !important;
    font-weight: 600 !important;
    color: var(--sos-text) !important;
    border: none !important;
    border-left: 1.5px solid var(--sos-border) !important;
    border-right: 1.5px solid var(--sos-border) !important;
}

/* --- Hide redundant info under product name --- */
body.woocommerce-cart .wc-block-cart-item__product .wc-block-components-product-price,
body.woocommerce-cart .wc-block-cart-item__product .wc-block-components-product-metadata,
body.woocommerce-cart .wc-block-cart-item__product .wc-block-components-sale-badge,
body.woocommerce-cart .wc-block-cart-item__product .wc-block-components-product-details {
    display: none !important;
}

/* --- Remove button --- */
body.woocommerce-cart .wc-block-cart-item__remove-link {
    font-size: 0.78rem !important;
    color: var(--sos-text-light) !important;
    opacity: 0.7;
    transition: color 0.2s, opacity 0.2s !important;
}
body.woocommerce-cart .wc-block-cart-item__remove-link:hover {
    color: #e53e3e !important;
    opacity: 1;
}

/* --- Row total --- */
body.woocommerce-cart .wc-block-cart-items__row .wc-block-cart-item__total .wc-block-formatted-money-amount {
    font-family: var(--sos-font) !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--sos-navy) !important;
}

/* =====================================================
   SIDEBAR
   ===================================================== */
body.woocommerce-cart .wc-block-cart__sidebar {
    background: var(--sos-bg) !important;
    border: 1.5px solid var(--sos-border) !important;
    border-radius: var(--sos-radius) !important;
    padding: 24px !important;
    box-shadow: var(--sos-shadow) !important;
    position: sticky !important;
    top: 100px !important;
    align-self: flex-start !important;
}

/* --- Title --- */
body.woocommerce-cart .wc-block-cart__totals-title {
    font-family: var(--sos-font) !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    color: var(--sos-navy) !important;
    padding-bottom: 16px !important;
    margin-bottom: 0 !important;
    border-bottom: 2px solid var(--sos-border) !important;
}

/* --- Totals rows --- */
body.woocommerce-cart .wc-block-components-totals-item {
    font-family: var(--sos-font) !important;
}
body.woocommerce-cart .wc-block-components-totals-item__label {
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: var(--sos-text) !important;
}
body.woocommerce-cart .wc-block-components-totals-item__value .wc-block-formatted-money-amount {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--sos-navy) !important;
}

/* --- Footer total --- */
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--sos-text) !important;
}
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-formatted-money-amount {
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    color: var(--sos-navy) !important;
}

/* --- Coupon --- */
body.woocommerce-cart .wc-block-components-totals-coupon .wc-block-components-panel__button {
    font-family: var(--sos-font) !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    color: var(--sos-blue-light) !important;
}
body.woocommerce-cart .wc-block-components-totals-coupon__form .wc-block-components-text-input input {
    border-radius: 8px !important;
    border: 1.5px solid var(--sos-border) !important;
    font-family: var(--sos-font) !important;
}
body.woocommerce-cart .wc-block-components-totals-coupon__button,
body.woocommerce-cart .wc-block-components-totals-coupon__button.wp-element-button,
body.woocommerce-cart .wc-block-components-totals-coupon__form .wc-block-components-button {
    background: var(--sos-blue-light) !important;
    color: #fff !important;
    border-radius: 8px !important;
    font-family: var(--sos-font) !important;
    font-weight: 600 !important;
    border: none !important;
}

/* --- Express payment separator --- */
body.woocommerce-cart .wc-block-components-express-payment__title-container {
    font-family: var(--sos-font) !important;
    color: var(--sos-text-light) !important;
}

/* =====================================================
   CTA BUTTON
   ===================================================== */
body.woocommerce-cart .wc-block-cart__submit-button,
body.woocommerce-cart .wc-block-cart__submit-button.wp-element-button,
body.woocommerce-cart .wc-block-cart__submit-button.contained {
    background: linear-gradient(135deg, var(--sos-green) 0%, var(--sos-green-dark) 100%) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-family: var(--sos-font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    padding: 16px 32px !important;
    letter-spacing: 0.02em !important;
    transition: all 0.25s ease !important;
    box-shadow: 0 4px 14px rgba(74, 158, 47, 0.25) !important;
    text-transform: none !important;
    width: 100% !important;
}
body.woocommerce-cart .wc-block-cart__submit-button:hover {
    background: linear-gradient(135deg, var(--sos-green-dark) 0%, #3d8c26 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(74, 158, 47, 0.4) !important;
}
body.woocommerce-cart .wc-block-cart__submit-button:active {
    transform: translateY(0) !important;
}

/* --- Loading/Processing state --- */
body.woocommerce-cart .wc-block-cart__submit-button[aria-busy="true"],
body.woocommerce-cart .wc-block-cart__submit-button[disabled],
body.woocommerce-cart .wc-block-cart__submit-button.cart-processing {
    opacity: 0.85 !important;
    cursor: wait !important;
    pointer-events: none !important;
    transform: none !important;
    box-shadow: 0 2px 8px rgba(74, 158, 47, 0.2) !important;
}
body.woocommerce-cart .wc-block-cart__submit-button[aria-busy="true"]:hover,
body.woocommerce-cart .wc-block-cart__submit-button.cart-processing:hover {
    transform: none !important;
    box-shadow: 0 2px 8px rgba(74, 158, 47, 0.2) !important;
}
.cart-btn-spinner {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 2.5px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: cartSpin 0.7s linear infinite;
    vertical-align: middle;
    margin-right: 8px;
    margin-top: -2px;
}
@keyframes cartSpin {
    to { transform: rotate(360deg); }
}

/* =====================================================
   TRUST SIGNALS
   ===================================================== */
.cart-trust {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--sos-border);
    font-family: var(--sos-font);
}
.cart-trust-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 5px;
}
.cart-trust-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cart-trust-icon-secure { background: rgba(43, 108, 176, 0.1); }
.cart-trust-icon-download { background: rgba(91, 168, 160, 0.12); }
.cart-trust-icon-has { background: rgba(245, 158, 11, 0.1); }
.cart-trust-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--sos-text-light);
    line-height: 1.3;
}

/* =====================================================
   SAVINGS BANNER
   ===================================================== */
.cart-savings-banner {
    background: linear-gradient(135deg, #ecfdf5, #d1fae5);
    border: 1px solid #a7f3d0;
    border-radius: 8px;
    padding: 10px 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--sos-font);
}
.cart-savings-banner svg {
    flex-shrink: 0;
}
.cart-savings-text {
    font-size: 0.85rem;
    font-weight: 600;
    color: #065f46;
}
.cart-savings-amount {
    font-weight: 800;
    color: #047857;
}

/* =====================================================
   BUNDLE ITEMS — Hide child items
   ===================================================== */
body.woocommerce-cart .wc-block-cart-items__row.is-bundled,
body.woocommerce-cart .wc-block-cart-items__row[data-is-bundled="true"],
body.woocommerce-cart tr.bundled_table_item,
body.woocommerce-cart .cart_item.bundled_table_item,
body.woocommerce-cart .wc-block-cart-items__row.bundled,
body.woocommerce-cart .wc-block-cart-items__row .bundled-product-child {
    display: none !important;
}

/* =====================================================
   RESPONSIVE
   ===================================================== */

/* Tablet (max-width 900px) */
@media (max-width: 900px) {
    .cart-header {
        padding: 12px 16px 16px;
    }
    .cart-header h1 {
        font-size: 1.3rem !important;
    }
    .cart-stepper {
        padding: 16px 16px 0;
    }
    .cart-step {
        font-size: 0.8rem;
    }
    .cart-step-sep {
        width: 28px;
        margin: 0 6px;
    }
    body.woocommerce-cart .wp-block-woocommerce-cart {
        padding: 0 16px 32px !important;
    }
    body.woocommerce-cart .wc-block-cart__sidebar {
        position: static !important;
    }
    body.woocommerce-cart .wc-block-cart .wc-block-cart__main,
    body.woocommerce-cart .wc-block-cart .wc-block-cart__sidebar {
        flex: 1 1 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
}

/* Mobile (max-width 600px) */
@media (max-width: 600px) {
    .cart-header-top {
        flex-direction: column;
        align-items: flex-start;
    }
    .cart-stepper {
        padding: 12px 12px 0;
    }
    .cart-step {
        font-size: 0.7rem;
        gap: 4px;
    }
    .cart-step-label {
        display: none;
    }
    .cart-step-num {
        width: 24px;
        height: 24px;
        font-size: 0.7rem;
    }
    .cart-step-sep {
        width: 20px;
        margin: 0 4px;
    }
    .cart-header {
        padding: 10px 12px 14px;
    }
    .cart-header h1 {
        font-size: 1.15rem !important;
    }
    body.woocommerce-cart .wp-block-woocommerce-cart {
        padding: 0 12px 24px !important;
    }
    body.woocommerce-cart .wc-block-cart-item__image img {
        width: 70px !important;
        height: 70px !important;
    }
    body.woocommerce-cart .wc-block-cart__sidebar {
        padding: 16px !important;
        border-radius: 10px !important;
    }
    .cart-trust {
        gap: 6px;
    }
    .cart-trust-label {
        font-size: 0.65rem;
    }
    .cart-trust-icon {
        width: 28px;
        height: 28px;
    }
    .cart-trust-icon svg {
        width: 13px;
        height: 13px;
    }
}

/* Print */
@media print {
    .cart-stepper,
    .cart-trust,
    .cart-savings-banner,
    .wc-block-cart__submit-container,
    .wc-block-components-express-payment {
        display: none !important;
    }
}
