/* ============================================================
 * THE PLAYING ELEVEN — WooCommerce styling
 *
 * This file STYLES the default WooCommerce templates rather than
 * overriding them. We keep WC's stock single-product.php, archive-product.php,
 * etc., so plugin compatibility (variations, gallery zoom, reviews, related)
 * keeps working. We just paint them with our brand palette and typography.
 * ============================================================ */

/* ------- SHARED LAYOUT ---------------------------------------------------- */
.pe-shop-wrap {
	padding: 60px 24px 80px;
}

.woocommerce-products-header { text-align: center; margin-bottom: 48px; }
.woocommerce-products-header__title.page-title {
	font-family: var(--pe-font-display);
	font-size: clamp(36px, 5vw, 60px);
	color: var(--pe-charcoal);
	margin: 0 0 12px;
}
.term-description { max-width: 700px; margin: 0 auto; color: var(--pe-gray-700); }

.woocommerce-breadcrumb {
	font-size: 13px;
	color: var(--pe-gray-500);
	margin-bottom: 24px;
	letter-spacing: .04em;
}
.woocommerce-breadcrumb a { color: var(--pe-gray-700); }
.woocommerce-breadcrumb a:hover { color: var(--pe-red); }

.woocommerce-result-count { color: var(--pe-gray-500); font-size: 14px; }
.woocommerce-ordering select {
	font-family: var(--pe-font-body);
	padding: 10px 14px;
	border: 2px solid var(--pe-gray-200);
	border-radius: var(--pe-radius-sm);
	background: var(--pe-white);
	font-size: 14px;
}
.woocommerce-ordering select:focus { border-color: var(--pe-red); outline: none; }

/* ------- SHOP / CATEGORY PRODUCT GRID ------------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	list-style: none;
	margin: 0 0 40px !important;
	padding: 0 !important;
}
@media (max-width: 1100px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 800px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: 1fr; }
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	background: var(--pe-white);
	border-radius: var(--pe-radius);
	overflow: hidden;
	box-shadow: var(--pe-shadow-sm);
	transition: all .3s var(--pe-ease);
	display: flex; flex-direction: column;
	padding: 0;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--pe-shadow);
}

.woocommerce ul.products li.product a img {
	margin: 0 !important;
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	transition: transform .5s var(--pe-ease);
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.05); }

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
	font-family: var(--pe-font-display) !important;
	font-size: 17px !important;
	font-weight: 600 !important;
	color: var(--pe-charcoal) !important;
	padding: 16px 18px 4px !important;
	margin: 0 !important;
	line-height: 1.25 !important;
	letter-spacing: .01em !important;
}
.woocommerce ul.products li.product .price {
	font-family: var(--pe-font-display) !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	color: var(--pe-red) !important;
	padding: 0 18px 12px !important;
	margin: 0 !important;
}
.woocommerce ul.products li.product .price del { color: var(--pe-gray-500) !important; opacity: .7; margin-right: 6px; font-weight: 400; }
.woocommerce ul.products li.product .price ins { background: transparent !important; text-decoration: none !important; }

.woocommerce ul.products li.product .star-rating { margin: 0 18px 8px !important; font-size: 12px; color: var(--pe-red); }
.woocommerce .star-rating::before { color: var(--pe-gray-200); }
.woocommerce .star-rating span::before { color: var(--pe-red); }

.woocommerce ul.products li.product .button {
	display: block !important;
	margin: 0 18px 18px !important;
	padding: 10px 16px !important;
	background: var(--pe-charcoal) !important;
	color: var(--pe-white) !important;
	text-align: center;
	border-radius: var(--pe-radius-sm) !important;
	font-family: var(--pe-font-display) !important;
	font-size: 12px !important;
	letter-spacing: .15em !important;
	text-transform: uppercase !important;
	font-weight: 600 !important;
	border: 0 !important;
	transition: background .2s var(--pe-ease);
}
.woocommerce ul.products li.product .button:hover { background: var(--pe-red) !important; }
.woocommerce ul.products li.product .added_to_cart {
	display: block !important;
	margin: 0 18px 18px !important;
	padding: 10px 16px !important;
	background: var(--pe-blue) !important;
	color: var(--pe-white) !important;
	text-align: center !important;
	border-radius: var(--pe-radius-sm);
	font-family: var(--pe-font-display);
	font-size: 12px !important;
	letter-spacing: .15em !important;
	text-transform: uppercase !important;
	font-weight: 600 !important;
	text-decoration: none !important;
}

.woocommerce span.onsale {
	background: var(--pe-red) !important;
	color: var(--pe-white) !important;
	font-family: var(--pe-font-display) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: .15em !important;
	text-transform: uppercase;
	min-width: 0 !important;
	min-height: 0 !important;
	padding: 4px 10px !important;
	border-radius: 4px !important;
	line-height: 1 !important;
	margin: 12px 0 0 12px !important;
	top: 0 !important; left: 0 !important;
	right: auto !important;
}

/* ------- SINGLE PRODUCT --------------------------------------------------- */
/* We DO NOT replace single-product.php — only paint the default markup. */

.woocommerce div.product .product_title {
	font-family: var(--pe-font-display) !important;
	font-size: clamp(28px, 4vw, 42px) !important;
	color: var(--pe-charcoal) !important;
	letter-spacing: .01em;
	margin-bottom: 12px !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-family: var(--pe-font-display) !important;
	font-size: 32px !important;
	color: var(--pe-red) !important;
	font-weight: 600 !important;
}
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 20px; }
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--pe-gray-700);
	line-height: 1.7;
	margin-bottom: 24px;
}

.woocommerce div.product form.cart .quantity input.qty {
	padding: 12px 10px !important;
	border: 2px solid var(--pe-gray-200) !important;
	border-radius: var(--pe-radius-sm) !important;
	font-size: 16px !important;
	text-align: center;
	width: 70px !important;
}
.woocommerce div.product form.cart .button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background: var(--pe-red) !important;
	color: var(--pe-white) !important;
	font-family: var(--pe-font-display) !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	letter-spacing: .12em !important;
	text-transform: uppercase !important;
	padding: 14px 28px !important;
	border-radius: var(--pe-radius-sm) !important;
	border: 0 !important;
	transition: all .2s var(--pe-ease) !important;
}
.woocommerce div.product form.cart .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
	background: var(--pe-red-dark) !important;
	transform: translateY(-2px);
	box-shadow: var(--pe-shadow);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	border-bottom: 2px solid var(--pe-gray-200) !important;
	padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin: 0 8px 0 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	font-family: var(--pe-font-display) !important;
	font-size: 14px !important;
	letter-spacing: .12em !important;
	text-transform: uppercase !important;
	color: var(--pe-gray-700) !important;
	padding: 14px 18px !important;
	display: block;
	border-bottom: 3px solid transparent;
	margin-bottom: -2px;
	font-weight: 600;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--pe-red) !important;
	border-bottom-color: var(--pe-red);
}

.woocommerce div.product .woocommerce-tabs .panel {
	padding: 32px 0 !important;
}

.woocommerce .related.products h2,
.woocommerce .upsells.products h2 {
	font-family: var(--pe-font-display);
	font-size: clamp(24px, 3vw, 32px);
	margin: 60px 0 32px;
}

/* ------- CART ------------------------------------------------------------- */
.woocommerce table.shop_table {
	border: 0 !important;
	background: var(--pe-white);
	border-radius: var(--pe-radius);
	overflow: hidden;
	box-shadow: var(--pe-shadow-sm);
}
.woocommerce table.shop_table th {
	font-family: var(--pe-font-display) !important;
	font-size: 13px !important;
	letter-spacing: .12em !important;
	text-transform: uppercase !important;
	color: var(--pe-charcoal) !important;
	background: var(--pe-bone);
	padding: 16px !important;
}
.woocommerce table.shop_table td { padding: 20px 16px !important; vertical-align: middle; }
.woocommerce-cart .product-thumbnail img { width: 70px; border-radius: 6px; }
.woocommerce a.remove {
	color: var(--pe-red) !important;
	font-size: 22px;
}
.woocommerce a.remove:hover { background: var(--pe-red) !important; color: var(--pe-white) !important; }

.woocommerce .cart-collaterals .cart_totals {
	background: var(--pe-white);
	padding: 28px;
	border-radius: var(--pe-radius);
	box-shadow: var(--pe-shadow-sm);
}
.woocommerce .cart-collaterals .cart_totals h2 {
	font-family: var(--pe-font-display);
	font-size: 24px;
	margin: 0 0 16px;
}

/* ------- CHECKOUT --------------------------------------------------------- */
.woocommerce form .form-row label { font-weight: 500; color: var(--pe-charcoal); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	padding: 12px 14px !important;
	border: 2px solid var(--pe-gray-200) !important;
	border-radius: var(--pe-radius-sm) !important;
	font-family: var(--pe-font-body) !important;
	font-size: 15px !important;
	background: var(--pe-cream) !important;
	transition: border-color .2s var(--pe-ease);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--pe-red) !important;
	background: var(--pe-white) !important;
	outline: none;
}

.woocommerce-checkout #payment {
	background: var(--pe-white) !important;
	border-radius: var(--pe-radius);
	padding: 28px !important;
	box-shadow: var(--pe-shadow-sm);
}
.woocommerce-checkout #payment ul.payment_methods { padding: 0 !important; }

/* ------- MY ACCOUNT ------------------------------------------------------- */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	background: var(--pe-white);
	border-radius: var(--pe-radius);
	padding: 12px;
	box-shadow: var(--pe-shadow-sm);
	list-style: none;
	margin: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li { padding: 0 !important; border: 0 !important; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 12px 16px;
	font-family: var(--pe-font-display);
	font-size: 14px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--pe-charcoal);
	border-radius: var(--pe-radius-sm);
	font-weight: 600;
	transition: all .15s var(--pe-ease);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background: var(--pe-red);
	color: var(--pe-white);
}

/* ------- MESSAGES --------------------------------------------------------- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top: 0 !important;
	padding: 16px 20px 16px 56px !important;
	border-radius: var(--pe-radius-sm) !important;
	font-family: var(--pe-font-body);
}
.woocommerce-message { background: #f0f9eb !important; }
.woocommerce-info    { background: #fff8e1 !important; }
.woocommerce-error   { background: #fdecea !important; color: var(--pe-red-dark) !important; }
.woocommerce-message::before { color: #4caf50 !important; }
.woocommerce-info::before    { color: var(--pe-blue) !important; }

/* ------- PAGINATION ------------------------------------------------------- */
.woocommerce nav.woocommerce-pagination ul,
.pagination, .navigation.pagination {
	margin-top: 32px;
	display: flex; justify-content: center; gap: 6px;
	border: 0 !important;
}
.woocommerce nav.woocommerce-pagination ul li {
	border: 0 !important;
	margin: 0 !important;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex !important;
	align-items: center; justify-content: center;
	min-width: 40px; height: 40px;
	padding: 0 12px !important;
	border-radius: var(--pe-radius-sm) !important;
	font-family: var(--pe-font-display);
	font-weight: 600;
	background: var(--pe-white) !important;
	color: var(--pe-charcoal) !important;
	border: 2px solid var(--pe-gray-200) !important;
	transition: all .2s var(--pe-ease);
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--pe-red) !important;
	color: var(--pe-white) !important;
	border-color: var(--pe-red) !important;
}
