/* =============================================
   Shopify-Style Cart & Checkout
   WooCommerce Blocks override
   ============================================= */

:root {
    --shop-bg: #f5f5f5;
    --shop-white: #ffffff;
    --shop-dark: #1a1a1a;
    --shop-text: #333333;
    --shop-muted: #707070;
    --shop-border: #e1e1e1;
    --shop-border-light: #ebebeb;
    --shop-green: #2d7a3a;
    --shop-green-hover: #245f2e;
    --shop-radius: 8px;
    --shop-radius-lg: 12px;
    --shop-input-height: 48px;
    --shop-font: inherit;
}

/* ══════════════════════════════════════
   GLOBAL — Cart & Checkout pages
   ══════════════════════════════════════ */

/* Page background */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.wc-block-cart,
.wc-block-checkout {
    background: var(--shop-bg) !important;
}

/* Max-width wrapper */
.wc-block-cart,
.wc-block-checkout {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 32px 24px !important;
    font-family: var(--shop-font) !important;
}

/* ══════════════════════════════════════
   LAYOUT — Sidebar (2-column)
   ══════════════════════════════════════ */

.wc-block-components-sidebar-layout {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 32px !important;
    align-items: flex-start !important;
}

.wc-block-components-sidebar-layout > .wc-block-components-main {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    max-width: none !important;
    order: 1 !important;
    width: auto !important;
}

.wc-block-components-sidebar-layout > .wc-block-components-sidebar {
    flex: 0 0 380px !important;
    width: 380px !important;
    min-width: 380px !important;
    max-width: 380px !important;
    order: 2 !important;
    position: sticky !important;
    top: 24px !important;
}

/* ══════════════════════════════════════
   CARDS — White card panels
   ══════════════════════════════════════ */

.wc-block-components-sidebar-layout > .wc-block-components-main,
.wc-block-components-sidebar-layout > .wc-block-components-sidebar {
    background: var(--shop-white) !important;
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius-lg) !important;
    padding: 32px !important;
    box-sizing: border-box !important;
}

/* ══════════════════════════════════════
   CART — Items list
   ══════════════════════════════════════ */

/* Cart heading */
.wc-block-cart .wc-block-components-main .wp-block-heading,
.wc-block-cart__heading {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
    margin: 0 0 24px !important;
    padding: 0 !important;
}

/* Cart items table */
.wc-block-cart-items {
    border: none !important;
}

.wc-block-cart-items th {
    display: none !important;
}

.wc-block-cart-items .wc-block-cart-items__row {
    border-bottom: 1px solid var(--shop-border-light) !important;
    padding: 20px 0 !important;
}

.wc-block-cart-items .wc-block-cart-items__row:last-child {
    border-bottom: none !important;
}

/* Product image */
.wc-block-cart-item__image {
    width: 80px !important;
    min-width: 80px !important;
}

.wc-block-cart-item__image img {
    border-radius: var(--shop-radius) !important;
    border: 1px solid var(--shop-border-light) !important;
}

/* Product name */
.wc-block-components-product-name {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
    text-decoration: none !important;
}

.wc-block-components-product-name:hover {
    color: var(--shop-green) !important;
}

/* Product metadata (variation info, area breakdown) */
.wc-block-components-product-details {
    font-size: 13px !important;
    color: var(--shop-muted) !important;
    margin-top: 4px !important;
}

/* Product price */
.wc-block-components-product-price {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
}

.wc-block-components-product-price .wc-block-components-product-price__regular {
    color: var(--shop-muted) !important;
    text-decoration: line-through !important;
}

/* Quantity selector — Shopify pill style */
.wc-block-components-quantity-selector {
    display: inline-flex !important;
    align-items: center !important;
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius) !important;
    overflow: hidden !important;
    height: 36px !important;
}

.wc-block-components-quantity-selector .wc-block-components-quantity-selector__button {
    background: var(--shop-white) !important;
    border: none !important;
    width: 36px !important;
    height: 100% !important;
    font-size: 16px !important;
    color: var(--shop-dark) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.wc-block-components-quantity-selector .wc-block-components-quantity-selector__button:hover {
    background: var(--shop-bg) !important;
}

.wc-block-components-quantity-selector .wc-block-components-quantity-selector__input {
    width: 40px !important;
    height: 100% !important;
    text-align: center !important;
    border: none !important;
    border-left: 1px solid var(--shop-border) !important;
    border-right: 1px solid var(--shop-border) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    padding: 0 !important;
    -moz-appearance: textfield !important;
}

/* Remove item link */
.wc-block-cart-item__remove-link {
    font-size: 13px !important;
    color: var(--shop-muted) !important;
    text-decoration: underline !important;
    margin-top: 8px !important;
}

.wc-block-cart-item__remove-link:hover {
    color: #dc3545 !important;
}

/* ══════════════════════════════════════
   TOTALS — Order summary sidebar
   ══════════════════════════════════════ */

.wc-block-components-totals-wrapper {
    border: none !important;
    padding: 0 !important;
}

.wc-block-components-totals-item {
    display: flex !important;
    justify-content: space-between !important;
    padding: 10px 0 !important;
    font-size: 14px !important;
    border-bottom: 1px solid var(--shop-border-light) !important;
}

.wc-block-components-totals-item:last-child {
    border-bottom: none !important;
}

.wc-block-components-totals-item__label {
    color: var(--shop-text) !important;
    font-weight: 400 !important;
}

.wc-block-components-totals-item__value {
    color: var(--shop-dark) !important;
    font-weight: 600 !important;
}

/* Grand total */
.wc-block-components-totals-footer-item {
    border-top: 2px solid var(--shop-dark) !important;
    padding-top: 16px !important;
    margin-top: 8px !important;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-size: 20px !important;
    font-weight: 700 !important;
}

/* Coupon section */
.wc-block-components-totals-coupon {
    border: none !important;
    padding: 16px 0 !important;
    border-top: 1px solid var(--shop-border-light) !important;
}

.wc-block-components-totals-coupon__button {
    font-size: 13px !important;
    color: var(--shop-green) !important;
    text-decoration: underline !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 0 !important;
}

/* ══════════════════════════════════════
   BUTTONS — Shopify style
   ══════════════════════════════════════ */

.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wc-block-components-button:not(.is-link) {
    background: var(--shop-green) !important;
    color: var(--shop-white) !important;
    border: none !important;
    border-radius: var(--shop-radius) !important;
    padding: 16px 32px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    height: auto !important;
    min-height: 52px !important;
}

.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover,
.wc-block-components-button:not(.is-link):hover {
    background: var(--shop-green-hover) !important;
}

/* Outline / secondary buttons */
.wc-block-components-button.is-link,
.wc-block-cart__submit-container .wc-block-components-button.outlined {
    background: transparent !important;
    color: var(--shop-green) !important;
    border: 1px solid var(--shop-green) !important;
}

/* ══════════════════════════════════════
   CHECKOUT — Form inputs (Shopify style)
   ══════════════════════════════════════ */

/* Text inputs */
.wc-block-components-text-input input,
.wc-block-components-text-input textarea {
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius) !important;
    height: var(--shop-input-height) !important;
    padding: 12px 14px !important;
    font-size: 14px !important;
    background: var(--shop-white) !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    box-sizing: border-box !important;
}

.wc-block-components-text-input input:focus,
.wc-block-components-text-input textarea:focus {
    border-color: var(--shop-green) !important;
    box-shadow: 0 0 0 2px rgba(45, 122, 58, 0.12) !important;
    outline: none !important;
}

/* Floating labels (Shopify style) */
.wc-block-components-text-input label {
    font-size: 13px !important;
    color: var(--shop-muted) !important;
    font-weight: 400 !important;
}

/* Select inputs */
.wc-block-components-select-input select,
.wc-blocks-components-select select,
.wc-block-components-combobox .components-form-token-field__input {
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius) !important;
    height: var(--shop-input-height) !important;
    padding: 12px 14px !important;
    font-size: 14px !important;
    background: var(--shop-white) !important;
}

/* ══════════════════════════════════════
   CHECKOUT — Step sections
   ══════════════════════════════════════ */

.wc-block-components-checkout-step {
    border-bottom: 1px solid var(--shop-border-light) !important;
    padding: 24px 0 !important;
    margin: 0 !important;
}

.wc-block-components-checkout-step:last-child {
    border-bottom: none !important;
}

.wc-block-components-checkout-step__heading,
.wc-block-components-checkout-step .wc-block-components-title,
.wc-block-checkout__form .wc-block-components-checkout-step .wc-block-components-title {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
    margin-bottom: 16px !important;
}

/* Override any theme/block green headings in checkout */
.wc-block-checkout h2,
.wc-block-checkout h3,
.wc-block-cart h2,
.wc-block-cart h3 {
    color: var(--shop-dark) !important;
}

.wc-block-components-checkout-step__description {
    font-size: 13px !important;
    color: var(--shop-muted) !important;
    margin-bottom: 16px !important;
}

/* ══════════════════════════════════════
   CHECKOUT — Shipping methods
   ══════════════════════════════════════ */

.wc-block-components-radio-control .wc-block-components-radio-control__option {
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius) !important;
    padding: 16px !important;
    margin-bottom: 8px !important;
    transition: border-color 0.15s !important;
}

.wc-block-components-radio-control .wc-block-components-radio-control__option:hover {
    border-color: var(--shop-green) !important;
}

.wc-block-components-radio-control .wc-block-components-radio-control__option--checked {
    border-color: var(--shop-green) !important;
    background: rgba(45, 122, 58, 0.03) !important;
}

.wc-block-components-radio-control__label {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--shop-dark) !important;
}

.wc-block-components-radio-control__secondary-label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
}

.wc-block-components-radio-control__description {
    font-size: 13px !important;
    color: var(--shop-muted) !important;
}

/* ══════════════════════════════════════
   CHECKOUT — Payment methods
   ══════════════════════════════════════ */

.wc-block-components-payment-method-label {
    font-size: 14px !important;
    font-weight: 500 !important;
}

.wc-block-components-payment-method-icons img {
    height: 24px !important;
    width: auto !important;
}

/* ══════════════════════════════════════
   CHECKOUT — Order summary (sidebar)
   ══════════════════════════════════════ */

/* Order summary heading */
.wc-block-components-panel__button,
.wc-block-components-panel .wc-block-components-panel__button {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--shop-dark) !important;
}

.wc-block-components-order-summary {
    border: none !important;
}

.wc-block-components-order-summary .wc-block-components-order-summary-item {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid var(--shop-border-light) !important;
    align-items: flex-start !important;
}

.wc-block-components-order-summary-item__image {
    width: 50px !important;
    min-width: 50px !important;
    flex-shrink: 0 !important;
    position: relative !important;
}

/* Product description takes available space */
.wc-block-components-order-summary-item__description {
    flex: 1 !important;
    min-width: 0 !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
}

.wc-block-components-order-summary-item__description .wc-block-components-product-name {
    font-size: 13px !important;
    display: block !important;
    white-space: normal !important;
    word-wrap: break-word !important;
}

.wc-block-components-order-summary-item__description .wc-block-components-product-metadata {
    font-size: 12px !important;
    color: var(--shop-muted) !important;
}

/* Price */
.wc-block-components-order-summary-item__total-price {
    flex-shrink: 0 !important;
    text-align: right !important;
    white-space: nowrap !important;
    font-weight: 600 !important;
    font-size: 14px !important;
}

.wc-block-components-order-summary-item__image img {
    border-radius: var(--shop-radius) !important;
    border: 1px solid var(--shop-border-light) !important;
}

/* Quantity badge on image (Shopify style) */
.wc-block-components-order-summary-item__quantity {
    position: absolute !important;
    top: -8px !important;
    right: -8px !important;
    background: var(--shop-muted) !important;
    color: var(--shop-white) !important;
    width: 22px !important;
    height: 22px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
}

.wc-block-components-order-summary-item__description {
    flex: 1 !important;
}

/* ══════════════════════════════════════
   EXPRESS PAYMENT (Apple Pay, Google Pay etc.)
   ══════════════════════════════════════ */

.wc-block-components-express-payment {
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius-lg) !important;
    padding: 20px !important;
    margin-bottom: 24px !important;
    background: var(--shop-bg) !important;
}

.wc-block-components-express-payment__title {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--shop-muted) !important;
    text-align: center !important;
    margin-bottom: 12px !important;
}

/* ══════════════════════════════════════
   NOTICES / ERRORS
   ══════════════════════════════════════ */

.wc-block-store-notices .wc-block-components-notice-banner {
    border-radius: var(--shop-radius) !important;
    padding: 14px 20px !important;
    font-size: 14px !important;
    border: none !important;
}

.wc-block-components-notice-banner.is-error {
    background: #fef2f2 !important;
    border-left: 4px solid #dc3545 !important;
}

.wc-block-components-notice-banner.is-success {
    background: #e8f5e9 !important;
    border-left: 4px solid var(--shop-green) !important;
}

.wc-block-components-notice-banner.is-info {
    background: #eff6ff !important;
    border-left: 4px solid #3b82f6 !important;
}

/* ══════════════════════════════════════
   EMPTY CART
   ══════════════════════════════════════ */

.wc-block-cart__empty-cart__title {
    font-size: 24px !important;
    font-weight: 600 !important;
    text-align: center !important;
    margin-bottom: 12px !important;
}

.wc-block-cart .wp-block-button .wc-block-components-button {
    max-width: 300px !important;
    margin: 16px auto !important;
}

/* ══════════════════════════════════════
   RESPONSIVE — Mobile
   ══════════════════════════════════════ */

@media only screen and (max-width: 767px) {

    /* Force all theme wrappers to use full viewport width */
    .woocommerce-cart .entry-content,
    .woocommerce-checkout .entry-content,
    .woocommerce-cart .section_wrapper,
    .woocommerce-checkout .section_wrapper,
    .woocommerce-cart .the_content_wrapper,
    .woocommerce-checkout .the_content_wrapper,
    .woocommerce-cart .content_wrapper .section_wrapper,
    .woocommerce-checkout .content_wrapper .section_wrapper,
    .woocommerce-cart .content_wrapper,
    .woocommerce-checkout .content_wrapper,
    .woocommerce-cart .container,
    .woocommerce-checkout .container {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .wc-block-cart,
    .wc-block-checkout {
        padding: 12px 8px !important;
        margin: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .wc-block-components-sidebar-layout {
        flex-wrap: wrap !important;
        gap: 12px !important;
    }

    .wc-block-components-sidebar-layout > .wc-block-components-main,
    .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
        flex: 1 1 100% !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
    }

    .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
        position: static !important;
    }

    /* Hide the sidebar order summary on checkout — it's already shown inline before Place Order */
    .woocommerce-checkout .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
        display: none !important;
    }

    .wc-block-components-sidebar-layout > .wc-block-components-main,
    .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
        padding: 12px !important;
        border-left: none !important;
        border-right: none !important;
        border-radius: 0 !important;
    }

    .wc-block-cart-item__image {
        width: 64px !important;
        min-width: 64px !important;
    }

    .wc-block-components-product-name {
        font-size: 14px !important;
    }

    .wc-block-cart__submit-button,
    .wc-block-components-checkout-place-order-button {
        min-height: 48px !important;
        font-size: 15px !important;
    }

    .wc-block-components-checkout-step__heading {
        font-size: 16px !important;
    }

    .wc-block-components-order-summary-item__image {
        width: 50px !important;
        min-width: 50px !important;
    }
}

/* ══════════════════════════════════════
   CLASSIC CART/CHECKOUT FALLBACK
   (in case classic shortcodes are used)
   ══════════════════════════════════════ */

.woocommerce-cart .woocommerce table.shop_table,
.woocommerce-checkout .woocommerce table.shop_table {
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius-lg) !important;
    overflow: hidden !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
}

.woocommerce-cart .woocommerce table.shop_table th,
.woocommerce-checkout .woocommerce table.shop_table th {
    background: var(--shop-bg) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: var(--shop-muted) !important;
    padding: 14px 16px !important;
}

.woocommerce-cart .woocommerce table.shop_table td,
.woocommerce-checkout .woocommerce table.shop_table td {
    padding: 16px !important;
    font-size: 14px !important;
    vertical-align: middle !important;
    border-top: 1px solid var(--shop-border-light) !important;
}

.woocommerce-cart .woocommerce .cart_totals {
    background: var(--shop-white) !important;
    border: 1px solid var(--shop-border) !important;
    border-radius: var(--shop-radius-lg) !important;
    padding: 24px !important;
}

.woocommerce-cart .woocommerce .wc-proceed-to-checkout .checkout-button,
.woocommerce-checkout .woocommerce #place_order {
    background: var(--shop-green) !important;
    color: var(--shop-white) !important;
    border: none !important;
    border-radius: var(--shop-radius) !important;
    padding: 16px 32px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

.woocommerce-cart .woocommerce .wc-proceed-to-checkout .checkout-button:hover,
.woocommerce-checkout .woocommerce #place_order:hover {
    background: var(--shop-green-hover) !important;
}
