/**
 * NNCC — WooCommerce FASE 3.1 (solo listado: tienda / archivo / taxonomías de producto)
 *
 * Capa de pulido sobre style.css: tokens NNCC (--nncc-yellow, --nncc-black, --nncc-white).
 * Alcance: body.nncc-wc-shop-page (ver inc/woocommerce.php).
 * Hero tienda principal: body.nncc-wc-main-shop (solo página Shop de Woo).
 */

/* -------------------------------------------------------------------------
   Tienda principal — hero (misma lógica visual que .nncc-inner-hero; tokens :root)
   Espaciado: sin hueco bajo el header (Understrap .wrapper { padding: 1.5rem 0 }),
   más aire bajo el hero antes del breadcrumb / listado.
------------------------------------------------------------------------- */
body.nncc-wc-main-shop #woocommerce-wrapper {
	overflow-x: hidden;
	padding-top: 0;
}

body.nncc-wc-main-shop .site-main,
body.nncc-wc-main-shop .content-area {
	padding-top: 0;
}

/* Sin imagen destacada: fondo institucional oscuro (imagen vía style inline si existe) */
body.nncc-wc-main-shop .nncc-wc-shop-hero {
	margin-top: 0;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-bottom: clamp(16px, 3vw, 32px);
	width: 100vw;
	max-width: 100vw;
	box-sizing: border-box;
	padding-top: 2.25rem;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-bottom: clamp(24px, 4vw, 48px);
	background-color: var(--nncc-black);
	color: var(--nncc-white);
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

body.nncc-wc-main-shop .nncc-wc-shop-hero[style*='background-image'] {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	min-height: 12rem;
}

body.nncc-wc-main-shop .nncc-wc-shop-hero[style*='background-image']::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(0, 0, 0, 0.6);
}

body.nncc-wc-main-shop .nncc-wc-shop-hero > * {
	position: relative;
	z-index: 2;
}

body.nncc-wc-main-shop .nncc-wc-shop-hero__inner {
	max-width: 72rem;
	margin: 0 auto;
	padding: 0 0.25rem;
}

body.nncc-wc-main-shop .nncc-wc-shop-hero__title {
	font-size: clamp(1.65rem, 2.8vw, 2.15rem);
	font-weight: 800;
	line-height: 1.2;
	color: var(--nncc-white);
	margin: 0 0 0.6rem;
	letter-spacing: -0.02em;
}

body.nncc-wc-main-shop .nncc-wc-shop-hero__title::after {
	content: '';
	display: block;
	width: 3rem;
	height: 4px;
	margin-top: 0.65rem;
	background: var(--nncc-yellow);
	border-radius: 2px;
}

body.nncc-wc-main-shop .nncc-wc-shop-hero__lead {
	font-size: 1.0625rem;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.88);
	margin: 0;
	max-width: 38rem;
}

@media (min-width: 768px) {
	body.nncc-wc-main-shop .nncc-wc-shop-hero {
		padding-top: 2.5rem;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-bottom: clamp(28px, 4vw, 48px);
	}

	body.nncc-wc-main-shop .nncc-wc-shop-hero[style*='background-image'] {
		min-height: 14rem;
	}
}

body.nncc-wc-main-shop .woocommerce-breadcrumb {
	margin-top: 8px;
}

/* -------------------------------------------------------------------------
   Encabezado de archivo: título + resultados + orden
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce-products-header {
	margin-bottom: 0.5rem;
}

.nncc-wc-shop-page .woocommerce .page-title,
.nncc-wc-shop-page.woocommerce-page .page-title {
	color: var(--nncc-black);
	font-weight: 800;
	letter-spacing: -0.01em;
}

.nncc-wc-shop-page .term-description {
	margin-bottom: 1.25rem;
	max-width: 65ch;
	color: rgba(0, 0, 0, 0.78);
	line-height: 1.6;
}

.nncc-wc-shop-page .woocommerce-result-count {
	font-weight: 700;
	color: var(--nncc-black);
	font-size: 0.95rem;
}

/* Fila típica: contador + selector (Woo ya usa flex en theme; reforzamos alineación) */
.nncc-wc-shop-page .woocommerce .woocommerce-ordering {
	margin-top: 0;
	margin-bottom: 1.25rem;
}

/* -------------------------------------------------------------------------
   Grid de productos
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products,
.nncc-wc-shop-page.woocommerce-page .woocommerce ul.products {
	column-gap: clamp(1rem, 2vw, 1.5rem);
	row-gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.nncc-wc-shop-page .woocommerce ul.products li.product {
	position: relative;
	border-color: rgba(0, 0, 0, 0.08);
	box-shadow: 0 8px 18px rgba(0, 0, 0, 0.04);
	transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.nncc-wc-shop-page .woocommerce ul.products li.product:hover {
	border-color: rgba(0, 0, 0, 0.12);
}

/* -------------------------------------------------------------------------
   Imagen / enlace de producto
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: block;
	border-radius: 10px;
	overflow: hidden;
}

.nncc-wc-shop-page .woocommerce ul.products li.product a.woocommerce-LoopProduct-link:focus-visible {
	outline: 2px solid var(--nncc-black);
	outline-offset: 3px;
}

/* -------------------------------------------------------------------------
   Título en loop
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product .woocommerce-loop-product__title,
.nncc-wc-shop-page .woocommerce ul.products li.product .woocommerce-loop-product__title a {
	color: var(--nncc-black);
	text-decoration: none;
	transition: color 0.15s ease;
}

.nncc-wc-shop-page .woocommerce ul.products li.product .woocommerce-loop-product__title a:hover {
	color: rgba(0, 0, 0, 0.72);
}

/* -------------------------------------------------------------------------
   Precios (incl. ofertas: del / ins)
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product .price {
	color: var(--nncc-black);
}

.nncc-wc-shop-page .woocommerce ul.products li.product .price del {
	opacity: 0.75;
	font-weight: 600;
	font-size: 0.92em;
}

.nncc-wc-shop-page .woocommerce ul.products li.product .price ins {
	text-decoration: none;
	font-weight: 800;
	color: var(--nncc-black);
}

/* -------------------------------------------------------------------------
   Badges (rebaja, etc.)
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product span.onsale {
	background: var(--nncc-yellow);
	color: var(--nncc-black);
	border: 2px solid var(--nncc-black);
	border-radius: var(--nncc-btn-radius);
	font-weight: 800;
	font-size: 0.72rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	min-height: 2rem;
	line-height: 1.1;
	padding: 0.35rem 0.65rem;
	box-shadow: 0 2px 0 rgba(0, 0, 0, 0.12);
}

/* Etiquetas adicionales (Woo 8+ / extensiones) */
.nncc-wc-shop-page .woocommerce ul.products li.product .wc-block-grid__product-onsale,
.nncc-wc-shop-page .woocommerce ul.products li.product .woocommerce-badge {
	border-radius: var(--nncc-btn-radius);
	font-weight: 800;
}

/* -------------------------------------------------------------------------
   Botón “Agregar al carrito” — foco accesible (sin duplicar colores de style.css)
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product .button:focus-visible,
.nncc-wc-shop-page .woocommerce ul.products li.product .add_to_cart_button:focus-visible,
.nncc-wc-shop-page .woocommerce ul.products li.product .ajax_add_to_cart:focus-visible {
	outline: 2px solid var(--nncc-black);
	outline-offset: 3px;
}

.nncc-wc-shop-page .woocommerce ul.products li.product.outofstock .button,
.nncc-wc-shop-page .woocommerce ul.products li.product.outofstock .add_to_cart_button {
	cursor: not-allowed;
	opacity: 0.88;
}

/* -------------------------------------------------------------------------
   Valoraciones en grilla (si se muestran)
------------------------------------------------------------------------- */
.nncc-wc-shop-page .woocommerce ul.products li.product .star-rating {
	margin-top: 0.25rem;
	margin-bottom: 0.35rem;
}

/* -------------------------------------------------------------------------
   Paginación del catálogo
------------------------------------------------------------------------- */
.nncc-wc-shop-page nav.woocommerce-pagination {
	margin-top: 2rem;
	margin-bottom: 0.5rem;
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers li {
	margin: 0;
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers a,
.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	min-height: 2.5rem;
	padding: 0.35rem 0.65rem;
	border-radius: var(--nncc-btn-radius);
	border: 2px solid var(--nncc-black);
	background: var(--nncc-white);
	color: var(--nncc-black);
	font-weight: 800;
	text-decoration: none;
	transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers a:hover {
	background: var(--nncc-yellow);
	color: var(--nncc-black);
	border-color: var(--nncc-black);
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers span.current {
	background: var(--nncc-yellow);
	color: var(--nncc-black);
	border-color: var(--nncc-black);
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers a:focus-visible {
	outline: 2px solid var(--nncc-black);
	outline-offset: 3px;
}

.nncc-wc-shop-page .woocommerce-pagination ul.page-numbers span.dots {
	border-color: transparent;
	background: transparent;
	min-width: auto;
}

/* -------------------------------------------------------------------------
   Bloques Woo (si el archivo usa Product Collection / grid de bloques)
------------------------------------------------------------------------- */
.nncc-wc-shop-page .wc-block-grid__product {
	border-radius: 12px;
	border: 1px solid rgba(0, 0, 0, 0.08);
	box-shadow: 0 8px 18px rgba(0, 0, 0, 0.04);
	overflow: hidden;
}

.nncc-wc-shop-page .wc-block-grid__product .wc-block-grid__product-title {
	font-weight: 700;
}

.nncc-wc-shop-page .wc-block-grid__product .wc-block-grid__product-price {
	font-weight: 800;
	color: var(--nncc-black);
}

.nncc-wc-shop-page .wc-block-grid__product .wp-block-button__link {
	border-radius: var(--nncc-btn-radius);
	font-weight: 800;
	background: var(--nncc-black);
	color: var(--nncc-yellow);
	border: 2px solid var(--nncc-black);
	transition: background-color 0.18s ease, color 0.18s ease;
}

.nncc-wc-shop-page .wc-block-grid__product .wp-block-button__link:hover {
	background: transparent;
	color: var(--nncc-black);
}
