/* ================================================================
   Urban Leaf Supply — woocommerce.css
   WooCommerce-specific overrides
   ================================================================ */

/* ----------------------------------------------------------------
   Remove default WC styles we don't need
   ---------------------------------------------------------------- */
.woocommerce-breadcrumb { display: none; } /* replaced by our breadcrumbs */
.woocommerce div.product .product_title { font-family: var(--font-heading); }
.woocommerce-page .woocommerce { max-width: none; }
.woocommerce .woocommerce-error,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message { border-top-color: var(--clr-green); }

/* ----------------------------------------------------------------
   Sort/filter selects
   ---------------------------------------------------------------- */
.woocommerce-ordering select {
    padding: 0.5rem 2rem 0.5rem 0.875rem;
    background-color: var(--clr-surface);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 14px;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-text-muted);
    font-size: 0.875rem;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
    transition: border-color var(--transition);
}
.woocommerce-ordering select:focus { outline: none; border-color: var(--clr-green); color: var(--clr-white); }

/* Result count */
.woocommerce-result-count { font-size: 0.875rem; color: var(--clr-text-faint); }

/* ----------------------------------------------------------------
   Product loop: Add to cart button
   ---------------------------------------------------------------- */
.woocommerce ul.products li.product .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    padding: 0.6em 1.2em;
    background: var(--clr-green);
    color: #000 !important;
    border-radius: var(--radius-sm);
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 2px solid var(--clr-green);
    transition: all var(--transition);
    white-space: nowrap;
    cursor: pointer;
    line-height: 1;
    text-decoration: none;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce ul.products li.product .button:hover {
    background: var(--clr-green-dim);
    border-color: var(--clr-green-dim);
    transform: none;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
    background: var(--clr-green);
    border-color: var(--clr-green);
    color: #000 !important;
}

/* ----------------------------------------------------------------
   Single product: quantity + add to cart
   ---------------------------------------------------------------- */
.woocommerce div.product form.cart .qty {
    width: 70px;
    padding: 0.75rem;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-white);
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    -moz-appearance: textfield;
}
.woocommerce div.product form.cart .qty::-webkit-inner-spin-button,
.woocommerce div.product form.cart .qty::-webkit-outer-spin-button { -webkit-appearance: none; }
.woocommerce div.product form.cart .qty:focus { outline: none; border-color: var(--clr-green); }

.woocommerce div.product form.cart .button {
    padding: 0.875rem 2rem;
    font-size: 0.875rem;
}
.woocommerce div.product form.cart { display: flex; gap: var(--space-sm); align-items: center; }

/* ----------------------------------------------------------------
   Product tabs
   ---------------------------------------------------------------- */
.woocommerce div.product .woocommerce-tabs { margin-top: var(--space-xl); }
.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--clr-border);
    margin-bottom: 0;
    padding: 0;
    background: none;
    list-style: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    margin: 0;
    padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: var(--space-md) var(--space-lg);
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
    transition: color var(--transition);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover { color: var(--clr-white); text-decoration: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    border-bottom-color: var(--clr-green);
    background: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--clr-green); }
.woocommerce div.product .woocommerce-tabs .panel {
    background: var(--clr-bg-card);
    border: 1px solid var(--clr-border);
    border-top: none;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    padding: var(--space-xl);
    margin: 0;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-size: 1.1rem;
    margin-bottom: var(--space-md);
    color: var(--clr-white);
}
.woocommerce div.product .woocommerce-tabs .panel p { color: var(--clr-text-muted); line-height: 1.8; }

/* ----------------------------------------------------------------
   Product meta
   ---------------------------------------------------------------- */
.woocommerce div.product .product_meta { margin-top: var(--space-lg); padding-top: var(--space-lg); border-top: 1px solid var(--clr-border); }
.woocommerce div.product .product_meta span { display: block; font-size: 0.85rem; color: var(--clr-text-faint); margin-bottom: 4px; }
.woocommerce div.product .product_meta span a { color: var(--clr-green); }

/* ----------------------------------------------------------------
   Cart / Checkout
   ---------------------------------------------------------------- */
.woocommerce table.shop_table,
.woocommerce-checkout-review-order-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}
.woocommerce table.shop_table th {
    background: var(--clr-surface);
    border-bottom: 2px solid var(--clr-border);
    padding: var(--space-md);
    text-align: left;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
}
.woocommerce table.shop_table td {
    border-bottom: 1px solid var(--clr-border);
    padding: var(--space-md);
    color: var(--clr-text-muted);
    vertical-align: middle;
}
.woocommerce table.shop_table td a { color: var(--clr-white); }
.woocommerce table.shop_table td a:hover { color: var(--clr-green); }

/* Cart coupon input */
.woocommerce .coupon input[type="text"] {
    padding: 0.75rem 1rem;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-white);
    width: 200px;
}
.woocommerce .coupon input[type="text"]:focus { outline: none; border-color: var(--clr-green); }

/* Cart totals box */
.woocommerce .cart-collaterals .cart_totals {
    background: var(--clr-bg-card);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}
.woocommerce .cart-collaterals .cart_totals h2 {
    font-size: 1.1rem;
    margin-bottom: var(--space-lg);
    color: var(--clr-white);
}
.woocommerce .cart_totals .order-total .amount { color: var(--clr-green); font-size: 1.5rem; font-weight: 700; }

/* Checkout form */
.woocommerce form.checkout h3,
.woocommerce form.checkout h2 { font-size: 1.2rem; margin-bottom: var(--space-lg); }
.woocommerce form .form-row { margin-bottom: var(--space-md); }
.woocommerce form .form-row label { font-size: 0.8rem; font-weight: 600; color: var(--clr-text-muted); text-transform: uppercase; letter-spacing: 0.06em; display: block; margin-bottom: 4px; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
    width: 100%;
    padding: 0.875rem 1rem;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-white);
    font-family: var(--font-body);
    transition: border-color var(--transition);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus { outline: none; border-color: var(--clr-green); }

/* Order received page */
.woocommerce-order { padding: var(--space-3xl) 0; }
.woocommerce-thankyou-order-received { font-size: 1.1rem; color: var(--clr-green); font-weight: 600; }

/* ----------------------------------------------------------------
   Notices
   ---------------------------------------------------------------- */
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
    background: var(--clr-bg-card) !important;
    border: 1px solid var(--clr-border) !important;
    border-left: 4px solid var(--clr-green) !important;
    color: var(--clr-text-muted) !important;
    border-radius: var(--radius-md) !important;
    padding: var(--space-md) var(--space-lg) !important;
    margin-bottom: var(--space-lg) !important;
    list-style: none !important;
}
.woocommerce-error { border-left-color: var(--clr-error) !important; }
.woocommerce-error a, .woocommerce-info a, .woocommerce-message a { color: var(--clr-green); }

/* Mini cart */
.woocommerce-mini-cart { padding: var(--space-lg); }
.woocommerce-mini-cart__empty-message { color: var(--clr-text-muted); }
.widget_shopping_cart .total { font-weight: 700; }
.widget_shopping_cart .total .amount { color: var(--clr-green); }

/* ----------------------------------------------------------------
   Star ratings
   ---------------------------------------------------------------- */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--clr-green); }
.woocommerce .review-title { color: var(--clr-white); }
.woocommerce .comment-text { background: var(--clr-bg-card); border: 1px solid var(--clr-border); border-radius: var(--radius-md); padding: var(--space-lg); }

/* ----------------------------------------------------------------
   WooCommerce product attributes table
   ---------------------------------------------------------------- */
.woocommerce-product-attributes { width: 100%; border-collapse: collapse; }
.woocommerce-product-attributes-item { border-bottom: 1px solid var(--clr-border); }
.woocommerce-product-attributes-item__label {
    width: 30%;
    padding: var(--space-sm) var(--space-md);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--clr-text-muted);
    background: var(--clr-surface);
}
.woocommerce-product-attributes-item__value {
    padding: var(--space-sm) var(--space-md);
    color: var(--clr-text-muted);
    font-size: 0.9rem;
}

/* ----------------------------------------------------------------
   Variable product swatches / variation selects
   ---------------------------------------------------------------- */
.woocommerce div.product form.cart .variations { width: 100%; margin-bottom: var(--space-lg); }
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    padding: var(--space-sm) 0;
    border: none;
}
.woocommerce div.product form.cart .variations label { color: var(--clr-text-muted); font-size: 0.875rem; font-weight: 600; }
.woocommerce div.product form.cart .variations select {
    padding: 0.6rem 2rem 0.6rem 0.875rem;
    background-color: var(--clr-surface);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.5rem center;
    background-size: 14px;
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-sm);
    color: var(--clr-white);
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
}
.woocommerce div.product form.cart .variations select:focus { outline: none; border-color: var(--clr-green); }
.woocommerce div.product form.cart .reset_variations { color: var(--clr-text-faint); font-size: 0.8rem; }
.woocommerce div.product form.cart .reset_variations:hover { color: var(--clr-green); }

/* ----------------------------------------------------------------
   Layered nav / widget
   ---------------------------------------------------------------- */
.widget_layered_nav ul { list-style: none; padding: 0; }
.widget_layered_nav ul li { padding: 4px 0; }
.widget_layered_nav ul li a { color: var(--clr-text-muted); font-size: 0.875rem; transition: color var(--transition); }
.widget_layered_nav ul li a:hover { color: var(--clr-green); text-decoration: none; }
.widget_layered_nav ul li.wc-layered-nav-term--chosen a { color: var(--clr-green); font-weight: 600; }
.widget_price_filter .price_slider_wrapper .ui-slider { background: var(--clr-border); border-radius: 4px; height: 4px; margin: 10px 0; }
.widget_price_filter .price_slider_wrapper .ui-slider .ui-slider-range { background: var(--clr-green); }
.widget_price_filter .price_slider_wrapper .ui-slider .ui-slider-handle { background: var(--clr-green); border: none; width: 14px; height: 14px; top: -5px; }

/* ----------------------------------------------------------------
   Responsive WC
   ---------------------------------------------------------------- */
@media (max-width: 768px) {
    .woocommerce div.product form.cart { flex-wrap: wrap; }
    .woocommerce table.shop_table td:before { content: attr(data-title); font-weight: 600; display: block; font-size: 0.75rem; text-transform: uppercase; color: var(--clr-text-faint); margin-bottom: 4px; }
    .woocommerce-product-attributes-item__label { width: 40%; }
}
