/*
 * WooCommerce CSS Overrides
 * Replaces WC's default stylesheet with our design system.
 * All variables are inherited from style.css :root.
 */

/* ============================================================
   RESET WC DEFAULTS
   ============================================================ */
.woocommerce-page .woocommerce,
.woocommerce-page #content,
.woocommerce-page #primary,
.woocommerce-page #main { padding: 0; }

/* ============================================================
   PRODUCT LOOP
   ============================================================ */
.woocommerce ul.products { margin: 0; padding: 0; }
.woocommerce ul.products li.product { margin: 0; padding: 0; float: none; width: auto; }

/* Hover underline on product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--font-body);
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    color: var(--color-primary);
    padding: 0;
    margin: 0 0 var(--space-2) 0;
}

/* Star rating in loop */
.woocommerce ul.products li.product .star-rating {
    color: var(--color-secondary);
    font-size: var(--fs-sm);
    margin: 0 0 var(--space-2);
}

/* Price in loop */
.woocommerce ul.products li.product .price {
    color: var(--color-primary);
    font-weight: var(--fw-semibold);
    font-size: var(--fs-base);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.woocommerce ul.products li.product .price del {
    color: var(--color-text-light);
    font-weight: var(--fw-regular);
    font-size: var(--fs-sm);
    opacity: 1;
}

.woocommerce ul.products li.product .price ins {
    text-decoration: none;
    color: var(--color-error);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button {
    background: var(--color-primary);
    color: var(--color-white);
    border: var(--border-width-2) solid var(--color-primary);
    border-radius: var(--radius-sm);
    font-family: var(--font-accent);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    padding: var(--space-3) var(--space-8);
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-base);
    cursor: pointer;
    text-decoration: none;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
    color: var(--color-white);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: var(--color-accent-dark);
    border-color: var(--color-accent-dark);
}

/* Add to cart button in single product */
.woocommerce .single_add_to_cart_button {
    flex: 1;
    min-height: 54px;
    font-size: var(--fs-base);
}

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
/* Title */
.woocommerce div.product .product_title {
    font-family: var(--font-heading);
    font-size: clamp(var(--fs-2xl), 3vw, var(--fs-4xl));
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    color: var(--color-primary);
    margin-bottom: var(--space-4);
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-size: var(--fs-3xl);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
    display: flex;
    align-items: baseline;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-6);
    border-bottom: var(--border-width) solid var(--color-border);
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    font-size: var(--fs-xl);
    color: var(--color-text-light);
    font-weight: var(--fw-regular);
    opacity: 1;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    text-decoration: none;
    color: var(--color-error);
}

/* Star rating */
.woocommerce div.product .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}

.star-rating { color: var(--color-secondary); }

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-6);
    font-size: 0.95rem;
}

/* Quantity */
.woocommerce div.product form.cart .qty {
    width: 60px;
    height: 54px;
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    text-align: center;
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    font-family: var(--font-body);
    background: var(--color-white);
    color: var(--color-text);
}

.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}

/* Variation form */
.woocommerce div.product form.cart .variations {
    width: 100%;
    margin-bottom: var(--space-4);
    border-collapse: collapse;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    padding: var(--space-2) 0;
    vertical-align: middle;
}

.woocommerce div.product form.cart .variations label {
    font-family: var(--font-accent);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    color: var(--color-text);
    white-space: nowrap;
    padding-right: var(--space-4);
}

.woocommerce div.product form.cart .variations select {
    padding: var(--space-2) var(--space-4);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--fs-sm);
    font-family: var(--font-body);
    background: var(--color-white);
    color: var(--color-text);
    outline: none;
    min-width: 200px;
}

/* Product meta (SKU, category) */
.woocommerce div.product .product_meta {
    padding-top: var(--space-5);
    border-top: var(--border-width) solid var(--color-border);
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
}

.woocommerce div.product .product_meta > span {
    display: block;
    margin-bottom: var(--space-2);
}

.woocommerce div.product .product_meta > span strong,
.woocommerce div.product .product_meta > span .sku_wrapper,
.woocommerce div.product .product_meta > span label {
    font-weight: var(--fw-semibold);
    color: var(--color-text);
    margin-right: var(--space-2);
}

.woocommerce div.product .product_meta a {
    color: var(--color-secondary);
}

/* ============================================================
   PRODUCT GALLERY (override WC defaults)
   ============================================================ */
.woocommerce div.product div.images {
    position: sticky;
    top: calc(var(--header-height) + var(--space-6));
}

.woocommerce div.product div.images .woocommerce-product-gallery__image:first-child {
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--space-4);
}

.woocommerce div.product div.images .woocommerce-product-gallery__image img {
    border-radius: var(--radius-lg);
    width: 100%;
}

.woocommerce div.product div.images .flex-control-thumbs {
    display: flex;
    gap: var(--space-3);
    overflow-x: auto;
    scrollbar-width: none;
    margin: 0;
    padding: 0;
}

.woocommerce div.product div.images .flex-control-thumbs li {
    flex-shrink: 0;
    width: 80px;
    list-style: none;
    margin: 0;
}

.woocommerce div.product div.images .flex-control-thumbs img {
    border-radius: var(--radius-md);
    border: 2px solid transparent;
    transition: border-color var(--transition-fast);
    cursor: pointer;
}

.woocommerce div.product div.images .flex-control-thumbs img.flex-active,
.woocommerce div.product div.images .flex-control-thumbs img:hover {
    border-color: var(--color-primary);
}

/* ============================================================
   PRODUCT TABS
   ============================================================ */
.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    border-bottom: var(--border-width) solid var(--color-border);
    list-style: none;
    margin: 0 0 2rem;
    padding: 0;
    overflow-x: auto;
    scrollbar-width: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    flex-shrink: 0;
    margin: 0;
    border: none;
    background: none;
    border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: var(--space-4) var(--space-6);
    font-family: var(--font-accent);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    color: var(--color-text-light);
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: all var(--transition-fast);
    text-decoration: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.woocommerce div.product .woocommerce-tabs .panel {
    border: none;
    padding: 0;
    background: none;
    margin: 0;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-size: var(--fs-xl);
    margin-bottom: var(--space-5);
}

/* ============================================================
   NOTICES & MESSAGES
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-5);
    font-size: var(--fs-sm);
    display: flex;
    align-items: center;
    gap: var(--space-4);
    border-top: none !important;
    box-shadow: var(--shadow-sm);
}

.woocommerce-message {
    background: rgba(45,140,78,0.08);
    border-left: 3px solid var(--color-success);
    color: var(--color-success);
}

.woocommerce-info {
    background: rgba(41,128,185,0.08);
    border-left: 3px solid var(--color-info);
    color: var(--color-info);
}

.woocommerce-error {
    background: rgba(192,57,43,0.08);
    border-left: 3px solid var(--color-error);
    color: var(--color-error);
}

.woocommerce-message .button,
.woocommerce-info .button {
    margin-left: auto;
    min-height: 38px;
    padding: var(--space-2) var(--space-5);
    font-size: var(--fs-xs);
}

/* ============================================================
   CHECKOUT & CART FORMS
   ============================================================ */
.woocommerce form .form-row label {
    font-family: var(--font-accent);
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    color: var(--color-text);
    margin-bottom: var(--space-2);
    display: block;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: var(--fs-base);
    color: var(--color-text);
    background: var(--color-white);
    outline: none;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    min-height: 50px;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 3px rgba(201,169,110,0.15);
}

/* Cart table */
.woocommerce table.shop_table {
    border-collapse: collapse;
    width: 100%;
}

.woocommerce table.shop_table th {
    font-family: var(--font-accent);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--color-text);
    padding: var(--space-4);
    border-bottom: 2px solid var(--color-border);
    background: var(--color-bg-alt);
}

.woocommerce table.shop_table td {
    padding: var(--space-4);
    border-bottom: var(--border-width) solid var(--color-border);
    vertical-align: middle;
    color: var(--color-text-muted);
    font-size: var(--fs-sm);
}

.woocommerce table.cart td.product-name {
    font-weight: var(--fw-medium);
    color: var(--color-primary);
}

/* ============================================================
   RELATED PRODUCTS (styled like our loop)
   ============================================================ */
.woocommerce .related.products h2,
.woocommerce .upsells.products h2,
.woocommerce .cross-sells h2 {
    font-size: clamp(var(--fs-2xl), 3vw, var(--fs-3xl));
    text-align: center;
    margin-bottom: var(--space-8);
}

/* ============================================================
   RATING STARS
   ============================================================ */
.woocommerce-product-rating .star-rating,
.star-rating {
    color: var(--color-secondary);
    font-size: var(--fs-base);
}

.woocommerce-review-link {
    color: var(--color-text-light);
    font-size: var(--fs-sm);
}

/* ============================================================
   BREADCRUMB (WC default — hidden, we use ours)
   ============================================================ */
.woocommerce .woocommerce-breadcrumb { display: none; }

/* ============================================================
   SALE BADGE
   ============================================================ */
.woocommerce span.onsale {
    background: var(--color-error);
    color: var(--color-white);
    font-family: var(--font-accent);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    border-radius: var(--radius-sm);
    min-width: auto;
    min-height: auto;
    width: auto;
    height: auto;
    line-height: 1;
    padding: var(--space-1) var(--space-3);
    top: var(--space-3);
    left: var(--space-3);
    border-radius: var(--radius-sm);
}

/* ============================================================
   ACCOUNT PAGES
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul a {
    display: block;
    padding: var(--space-3) var(--space-5);
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
    border-bottom: var(--border-width) solid var(--color-border);
    transition: all var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul .is-active a {
    background: var(--color-bg-alt);
    color: var(--color-primary);
    padding-left: var(--space-6);
}

/* ============================================================
   RESPONSIVE OVERRIDES
   ============================================================ */
@media (max-width: 768px) {
    .woocommerce div.product div.images {
        position: static;
    }

    .woocommerce div.product form.cart .qty {
        width: 50px;
        height: 48px;
    }
}
