/* ============================================================
   Ariseweb Commerce — woocommerce.css
   Estilos de la tienda. Se carga solo en páginas de WooCommerce
   (ver inc/enqueue.php). Usa los tokens de main.css.
   ============================================================ */

/* ---------- LAYOUT DE ARCHIVO ---------- */
.shop-section .archive-layout { display: grid; grid-template-columns: 248px 1fr; gap: 40px; align-items: start; }
.shop-content--full { width: 100%; }
.shop-sidebar.filters { position: sticky; top: 96px; display: flex; flex-direction: column; }
.has-sticky-header .shop-sidebar.filters { top: 110px; }

.woocommerce-products-header { margin-bottom: var(--space-6); }
.woocommerce-products-header__title { margin: 0 0 10px; }
.term-description { color: var(--text-muted); }
.woocommerce-result-count { font-size: 14px; color: var(--text-muted); }
.woocommerce-ordering { margin-bottom: var(--space-6); }
.woocommerce-ordering select {
    border: 1px solid var(--border); border-radius: var(--radius-control);
    padding: 9px 14px; font-weight: 700; color: var(--green-900); background: #fff;
}

/* ---------- GRID DE PRODUCTOS ---------- */
.woocommerce ul.products,
ul.products {
    list-style: none; margin: 0; padding: 0;
    display: grid; gap: var(--space-6);
    grid-template-columns: repeat(var(--arsc-shop-cols, 3), 1fr);
}
.columns-2 ul.products, ul.products.columns-2 { --arsc-shop-cols: 2; }
.columns-3 ul.products, ul.products.columns-3 { --arsc-shop-cols: 3; }
.columns-4 ul.products, ul.products.columns-4 { --arsc-shop-cols: 4; }
.columns-5 ul.products, ul.products.columns-5 { --arsc-shop-cols: 5; }

ul.products li.product {
    display: flex; flex-direction: column; background: #fff;
    border: 1px solid var(--border); border-radius: var(--radius-card);
    overflow: hidden; margin: 0; transition: border-color .16s ease, transform .16s ease;
}
ul.products li.product:hover { border-color: var(--action); transform: translateY(-2px); }
.pc-media { position: relative; display: block; aspect-ratio: 4/3; overflow: hidden; }
.pc-media-link { display: block; height: 100%; }
.pc-media img { width: 100%; height: 100%; object-fit: cover; margin: 0; }
.pc-body { display: flex; flex-direction: column; gap: 8px; padding: var(--space-4); flex: 1; }
.pc-body .woocommerce-loop-product__title {
    font-family: var(--font-display); font-weight: 700; font-size: 18px; line-height: 1.25;
    color: var(--green-900); padding: 0; margin: 0;
}
ul.products li.product a.pc-media-link:hover + .pc-body .woocommerce-loop-product__title { color: var(--action); }
.pc-body .price {
    font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--green-900);
}
.pc-body .price del { color: var(--text-muted); font-weight: 400; font-size: 15px; margin-right: 8px; }
.pc-body .price ins { text-decoration: none; }
.pc-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 12px; }
.pc-btn { padding: 10px 16px; font-size: 14px; }

/* Badge de oferta */
span.onsale, .pc-media .onsale {
    position: absolute; top: 12px; left: 12px; z-index: 2; margin: 0;
    background: var(--arsc-color-offer); color: var(--green-900);
    font-family: var(--font-display); font-weight: 700; font-size: 12px;
    padding: 5px 10px; border-radius: var(--radius-control); min-height: auto; min-width: auto; line-height: 1.2;
}

/* Vista rápida */
.quick-view-btn {
    position: absolute; left: 12px; bottom: 12px; z-index: 2;
    background: rgba(255,255,255,.92); border: 1px solid var(--border); color: var(--green-900);
    font-size: 13px; font-weight: 700; padding: 7px 12px; border-radius: var(--radius-control);
    cursor: pointer; box-shadow: var(--shadow-float);
}

/* Estrellas */
.star-rating { color: var(--brown-500); }
.woocommerce-product-rating { display: flex; align-items: center; gap: 10px; }

/* ---------- FICHA DE PRODUCTO ---------- */
.single-product div.product { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12); align-items: start; }
.single-product div.product .woocommerce-product-gallery { position: sticky; top: 96px; }
.single-product div.product .woocommerce-product-gallery img { border-radius: var(--radius-container); }
.single-product div.product .product_title { margin: 0 0 12px; font-size: 40px; }
.single-product div.product .price {
    font-family: var(--font-display); font-weight: 900; font-size: 36px; color: var(--green-900);
    display: block; margin-bottom: 16px;
}
.single-product div.product .price del { color: var(--text-muted); font-weight: 400; font-size: 20px; }
.single-product div.product .price ins { text-decoration: none; }
.single-product .woocommerce-product-details__short-description { font-size: var(--body-lg-size); line-height: 1.6; color: var(--text); margin-bottom: 24px; }
.single-product .woocommerce-product-details__short-description p { margin-bottom: 12px; }

/* Cantidad */
.quantity { display: inline-flex; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); overflow: hidden; }
.quantity input.qty {
    width: 56px; height: 52px; border: none; text-align: center;
    font-family: var(--font-display); font-weight: 700; font-size: 17px; padding: 0;
}
.single-product form.cart { display: flex; flex-wrap: wrap; gap: 12px; align-items: stretch; margin-bottom: 24px; }
.addcart-btn, .single_add_to_cart_button { flex: 1; min-width: 200px; }

/* Variaciones */
.variations { width: 100%; border-collapse: collapse; margin-bottom: 16px; }
.variations th { text-align: left; padding: 8px 12px 8px 0; font-family: var(--font-display); color: var(--green-900); }
.variations td { padding: 8px 0; }
.variations select { max-width: 320px; }

/* Pestañas */
.woocommerce-tabs { margin-top: var(--space-12); }
.woocommerce-tabs ul.tabs { list-style: none; display: flex; flex-wrap: wrap; gap: 4px; margin: 0 0 var(--space-8); padding: 0; border-bottom: 1px solid var(--border); }
.woocommerce-tabs ul.tabs li { margin: 0; }
.woocommerce-tabs ul.tabs li a {
    display: block; font-family: var(--font-display); font-weight: 700; font-size: 16px;
    color: var(--text-muted); padding: 12px 18px; border-bottom: 3px solid transparent; margin-bottom: -1px;
}
.woocommerce-tabs ul.tabs li.active a { color: var(--green-900); border-bottom-color: var(--action); }
.woocommerce-Tabs-panel h2 { margin-bottom: 16px; }

/* Relacionados / upsells */
.related.products, .upsells.products { margin-top: var(--space-16); }
.related.products > h2, .upsells.products > h2 { margin-bottom: var(--space-8); }

/* ---------- NOTICES ---------- */
.woocommerce-message, .woocommerce-info, .woocommerce-error, .woocommerce-noreviews {
    list-style: none; border-radius: var(--radius-card); padding: 14px 18px; margin: 0 0 var(--space-6);
    border: 1px solid var(--border); background: #fff; font-size: 15px;
}
.woocommerce-message { border-left: 4px solid var(--green-600); background: var(--green-50); }
.woocommerce-info { border-left: 4px solid var(--brown-500); background: var(--brown-50); }
.woocommerce-error { border-left: 4px solid #c0392b; background: #fdecea; }
.woocommerce-message .button, .woocommerce-info .button { float: right; }

/* ---------- BARRA ENVÍO GRATIS ---------- */
.freeship-bar { margin-bottom: var(--space-6); padding: 16px 18px; border: 1px solid var(--border); border-radius: var(--radius-card); background: var(--green-50); }
.freeship-msg { margin: 0 0 10px; font-size: 14px; color: var(--green-900); font-weight: 600; }
.freeship-msg.is-complete { color: var(--green-700); }
.freeship-track { height: 8px; border-radius: var(--radius-pill); background: var(--green-100); overflow: hidden; }
.freeship-fill { display: block; height: 100%; background: var(--action); border-radius: var(--radius-pill); transition: width .3s ease; }

/* ---------- CARRITO ---------- */
.woocommerce-cart-form table.cart { width: 100%; border-collapse: collapse; }
.woocommerce-cart-form table.cart th { text-align: left; font-family: var(--font-display); color: var(--green-900); padding: 12px; border-bottom: 1px solid var(--border); }
.woocommerce-cart-form table.cart td { padding: 16px 12px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.cart_totals { border: 1px solid var(--border); border-radius: var(--radius-container); padding: var(--space-6); background: #fff; }
.cart_totals h2 { margin-bottom: 16px; }
.cart_totals table { width: 100%; }
.cart-collaterals { margin-top: var(--space-8); display: grid; grid-template-columns: 1fr; gap: var(--space-6); }
.wc-proceed-to-checkout .checkout-button { width: 100%; }

/* ---------- CHECKOUT ---------- */
.woocommerce-checkout .col2-set, .woocommerce-checkout #customer_details { display: grid; gap: var(--space-6); }
.woocommerce-checkout #order_review { border: 1px solid var(--border); border-radius: var(--radius-container); padding: var(--space-6); background: #fff; }
.woocommerce-checkout #order_review_heading { margin-bottom: 16px; }
.woocommerce form .form-row { margin-bottom: var(--space-4); }
.woocommerce form .form-row label { display: block; margin-bottom: 6px; font-size: 14px; font-weight: 600; color: var(--green-900); }
#place_order { width: 100%; margin-top: 16px; }

/* ---------- MI CUENTA ---------- */
.woocommerce-account .woocommerce { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-12); align-items: start; }
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; border-left: 2px solid var(--border); }
.woocommerce-MyAccount-navigation li a { display: block; padding: 10px 0 10px 16px; margin-left: -2px; border-left: 2px solid transparent; color: var(--text-muted); }
.woocommerce-MyAccount-navigation li.is-active a, .woocommerce-MyAccount-navigation li a:hover { color: var(--green-900); border-left-color: var(--action); font-weight: 700; }

/* Botones Woo → estilo del tema */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce .button {
    background: var(--arsc-color-accent); color: var(--green-900); border: 1px solid transparent;
    border-radius: var(--radius-control); font-family: var(--font-text); font-weight: 700;
    padding: 12px 20px; cursor: pointer; transition: background .15s ease, color .15s ease;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover, .woocommerce .button:hover {
    background: var(--action-hover); color: #fff;
}
.woocommerce a.button.alt, .woocommerce button.button.alt { background: var(--arsc-color-accent); color: var(--green-900); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
    .shop-section .archive-layout { grid-template-columns: 1fr; }
    .shop-sidebar.filters { position: static; }
    .single-product div.product { grid-template-columns: 1fr; gap: var(--space-8); }
    .single-product div.product .woocommerce-product-gallery { position: static; }
    .woocommerce-account .woocommerce { grid-template-columns: 1fr; gap: var(--space-8); }
}
@media (max-width: 560px) {
    ul.products { --arsc-shop-cols: 1 !important; }
}
