.CartContentStack {
    display: grid;
    gap: 20px;
}

.CartSection {
    display: grid;
    gap: 16px;
    padding: 20px;
    border-radius: 16px;
    border: 1px solid #e6ece8;
    background-color: #fff;
}

.CartSectionTitle {
    font-size: 1.1em;
    font-weight: 700;
    color: var(--MainText1);
}

.CartContentStack {
    .CartItemsSection {
        gap: 16px;
    }

    .CartItemsList {
        display: grid;
        gap: 12px;
    }

    .CartItem {
        display: grid;
        gap: 20px;
        grid-template-columns: minmax(0, 1fr) 260px;
        align-items: start;
    }

    .CartActionBox {
        display: grid;
        gap: 10px;
        justify-items: end;
    }

    .QuantityField {
        display: grid;
        gap: 5px;
        width: 100%;

        .Label {
            font-size: 0.9em;
            color: var(--SubText1);
        }
    }

    .QuantityInput {
        width: 100%;
    }

    .ButtonRow {
        display: grid;
        width: 100%;
        gap: 8px;
        grid-template-columns: 1fr;
    }

    .CartSummary {
        display: grid;
        gap: 10px;
        padding: 10px;

        .SummaryBox {
            display: grid;
            gap: 6px;
            width: 100%;
        }
    }

    .CartActions {
        display: grid;
        gap: 10px;
        justify-items: flex-start;
        padding: 10px;
    }

    .CartActionsButtons {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
    }

    .CartEmptyState {
        justify-items: center;
    }

    .EmptyMessage {
        text-align: center;
        color: var(--SubText1);
        padding: 20px 0;
    }
}

@media screen and (max-width: 900px) {
    .CartContentStack {
        .CartItem {
            grid-template-columns: 1fr;
        }

        .CartActionBox {
            justify-items: stretch;
        }

        .CartActions {
            .CartActionsButtons {
                width: 100%;
            }
        }
    }
}

.CartContentStack {
    .CartSummary {
        .SummaryMeta {
            color: var(--SubText1);
            font-size: 0.9em;
        }

        .SummaryRow {
            display: flex;
            justify-content: space-between;
            gap: 12px;
            color: var(--MainText2);
        }

        .SummaryRow--total {
            font-weight: 700;
            color: var(--MainText1);
        }

        .ItemsSubTotal,
        .GrandTotal {
            &.PriceDisplayStack {
                display: grid;
                gap: 2px;
                justify-items: end;
            }

            .PriceDisplayMain {
                font-weight: 700;
                line-height: 1.2;
            }

            .PriceDisplaySub {
                font-size: 0.76em;
                color: var(--SubText1);
                line-height: 1.3;
            }
        }

        .ItemsSubTotal .PriceDisplayMain {
            color: var(--MainText1);
        }

        .GrandTotal .PriceDisplayMain {
            font-size: 1.15em;
            color: var(--PrimaryColor);
        }

        .GrandTotal .PriceDisplaySub {
            color: var(--MainText2);
        }

        .ItemsTaxTotal {
            font-weight: 700;
            color: var(--MainText1);
        }
    }
}
