/*
Theme Name: komypets

WooCommerce styles override
*/

/**
 * Shop tables
 */
table.shop_table_responsive thead {
	display: none;
}

table.shop_table_responsive tbody th {
	display: none;
}

table.shop_table_responsive tr td {
	display: block;
	text-align: right;
	clear: both;
}

table.shop_table_responsive tr td::before {
	content: attr(data-title) ": ";
	float: left;
}

table.shop_table_responsive tr td.product-remove a {
	text-align: left;
}

table.shop_table_responsive tr td.product-remove::before {
	display: none;
}

table.shop_table_responsive tr td.actions::before,
table.shop_table_responsive tr td.download-actions::before {
	display: none;
}

table.shop_table_responsive tr td.download-actions .button {
	display: block;
	text-align: center;
}

@media screen and (min-width: 48em) {

	table.shop_table_responsive thead {
		display: table-header-group;
	}

	table.shop_table_responsive tbody th {
		display: table-cell;
	}

	table.shop_table_responsive tr th,
	table.shop_table_responsive tr td {
		text-align: left;
	}

	table.shop_table_responsive tr td {
		display: table-cell;
	}

	table.shop_table_responsive tr td::before {
		display: none;
	}
}

/**
 * Products
 */
ul.products {
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	clear: both;
}

ul.products li.product {
	list-style: none;
	position: relative;
	margin-bottom: 2em;
}

ul.products li.product img {
	display: block;
}

ul.products li.product .button {
	display: block;
}

ul.products li.product ul.variations {
	margin-top: .5rem;
}

.woo-variation-swatches ul.variations .wvs_archive_reset_variations.hide {
	display: none !important;
}

ul.products .button {
	font-size: 18px !important;
}

@media screen and (min-width: 48em) {

	ul.products li.product {
		width: 30.79667%;
		/* float: left; */
		margin-right: 3.8%;
	}

	ul.products li.product.first {
		clear: both;
	}

	ul.products li.product.last {
		margin-right: 0;
	}

	ul.products.columns-1 li.product {
		float: none;
		width: 100%;
	}

	ul.products.columns-2 li.product {
		width: 48.1%;
	}

	ul.products.columns-3 li.product {
		width: 30.79667%;
	}

	ul.products.columns-4 li.product {
		width: 22.15%;
	}

	ul.products.columns-5 li.product {
		width: 16.96%;
	}

	ul.products.columns-6 li.product {
		width: 13.49333%;
	}
}

/**
 * Single product
 */
.single-product div.product {
	position: relative;
}

.single-product div.product .woocommerce-product-gallery {
	position: relative;
	float: left;
}

.single-product div.product .woocommerce-product-gallery .woocommerce-product-gallery__trigger {
	position: absolute;
	top: 2em;
	right: 1em;
	display: block;
	z-index: 99;
}

.single-product div.product .woocommerce-product-gallery .flex-viewport {
	margin-bottom: 1em;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs {
	margin: 0;
	padding: 0;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li {
	list-style: none;
	cursor: pointer;
	float: left;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li img {
	opacity: 0.5;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
	opacity: 1;
}

.single-product div.product .woocommerce-product-gallery .flex-control-thumbs li:hover img {
	opacity: 1;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-2 .flex-control-thumbs li {
	width: 48.1%;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-2 .flex-control-thumbs li:nth-child(2n) {
	margin-right: 0;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-2 .flex-control-thumbs li:nth-child(2n+1) {
	clear: both;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-3 .flex-control-thumbs li {
	width: 30.79667%;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-3 .flex-control-thumbs li:nth-child(3n) {
	margin-right: 0;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-3 .flex-control-thumbs li:nth-child(3n+1) {
	clear: both;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-4 .flex-control-thumbs li {
	width: 22.15%;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-4 .flex-control-thumbs li:nth-child(4n) {
	margin-right: 0;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-4 .flex-control-thumbs li:nth-child(4n+1) {
	clear: both;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-5 .flex-control-thumbs li {
	width: 16.96%;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-5 .flex-control-thumbs li:nth-child(5n) {
	margin-right: 0;
}

.single-product div.product .woocommerce-product-gallery.woocommerce-product-gallery--columns-5 .flex-control-thumbs li:nth-child(5n+1) {
	clear: both;
}

.stock:empty::before {
	display: none;
}

.stock.in-stock {
	color: #0f834d;
}

.stock.out-of-stock {
	color: #e2401c;
}

/**
 * Checkout
 */
@media screen and (min-width: 768px) {

	.col2-set .form-row-first {
		float: left;
		margin-right: 3.8%;
	}

	.col2-set .form-row-last {
		float: right;
		margin-right: 0;
	}

	.col2-set .form-row-first,
	.col2-set .form-row-last {
		width: 48.1%;
	}
}

/**
 * General WooCommerce components
 */

/**
 * Header cart
 */
.site-header-cart {
	position: relative;
	margin: 0;
	padding: 0;
}

.site-header-cart .cart-contents {
	text-decoration: none;
}

.site-header-cart .widget_shopping_cart {
	display: none;
}

.site-header-cart .product_list_widget {
	margin: 0;
	padding: 0;
}

/**
 * Star rating
 */
.star-rating {
	overflow: hidden;
	position: relative;
	height: 1.618em;
	line-height: 1.618;
	width: 5.3em;
	font-family: star;
	font-weight: 400;
}

.star-rating::before {
	content: "\53\53\53\53\53";
	opacity: 0.25;
	float: left;
	top: 0;
	left: 0;
	position: absolute;
}

.star-rating span {
	overflow: hidden;
	float: left;
	top: 0;
	left: 0;
	position: absolute;
	padding-top: 1.5em;
}

.star-rating span::before {
	content: "\53\53\53\53\53";
	top: 0;
	position: absolute;
	left: 0;
	color: #4169e1;
}

p.stars a {
	position: relative;
	height: 1em;
	width: 1em;
	text-indent: -999em;
	display: inline-block;
	text-decoration: none;
	margin-right: 1px;
	font-weight: 400;
}

p.stars a::before {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 1em;
	height: 1em;
	line-height: 1;
	font-family: star;
	content: "\53";
	color: #404040;
	text-indent: 0;
	opacity: 0.25;
}

p.stars a:hover~a::before {
	content: "\53";
	color: #404040;
	opacity: 0.25;
}

p.stars:hover a::before {
	content: "\53";
	color: #4169e1;
	opacity: 1;
}

p.stars.selected a.active::before {
	content: "\53";
	color: #4169e1;
	opacity: 1;
}

p.stars.selected a.active~a::before {
	content: "\53";
	color: #404040;
	opacity: 0.25;
}

p.stars.selected a:not(.active)::before {
	content: "\53";
	color: #4169e1;
	opacity: 1;
}

/**
 * Tabs
 */
.woocommerce-tabs ul.tabs {
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: left;
}

.woocommerce-tabs ul.tabs li {
	display: block;
	margin: 0;
	position: relative;
}

.woocommerce-tabs ul.tabs li a {
	padding: 1em 0;
	display: block;
}

.woocommerce-tabs .panel h2:first-of-type {
	margin-bottom: 1em;
}

/**
 * Password strength meter
 */
.woocommerce-password-strength {
	text-align: right;
}

.woocommerce-password-strength.strong {
	color: #0f834d;
}

.woocommerce-password-strength.short {
	color: #e2401c;
}

.woocommerce-password-strength.bad {
	color: #e2401c;
}

.woocommerce-password-strength.good {
	color: #3d9cd2;
}

/**
 * Forms
 */
.form-row.woocommerce-validated input.input-text {
	box-shadow: inset 2px 0 0 #0f834d;
}

.form-row.woocommerce-invalid input.input-text {
	box-shadow: inset 2px 0 0 #e2401c;
}

.required {
	color: #f00;
}

/**
 * Notices
 */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
p.no-comments {
	background-color: #0f834d;
	clear: both;
}

.woocommerce-info,
.woocommerce-noreviews,
p.no-comments {
	background-color: #3d9cd2;
}

.woocommerce-error {
	background-color: #e2401c;
}

.demo_store {
	position: fixed;
	left: 0;
	bottom: 0;
	right: 0;
	margin: 0;
	padding: 1em;
	background-color: #3d9cd2;
	z-index: 9999;
}

@media screen and (min-width: 48em) {

	/**
	 * Header cart
	 */
	.site-header-cart .widget_shopping_cart {
		position: absolute;
		top: 100%;
		width: 100%;
		z-index: 999999;
		left: -999em;
		display: block;
		box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	}

	.site-header-cart:hover .widget_shopping_cart,
	.site-header-cart.focus .widget_shopping_cart {
		left: 0;
		display: block;
	}
}

/**
 * WooCommerce widgets
 */

/**
 * WooCommerce Price Filter
 */
.widget_price_filter .price_slider {
	margin-bottom: 1.5em;
}

.widget_price_filter .price_slider_amount {
	text-align: right;
	line-height: 2.4;
}

.widget_price_filter .price_slider_amount .button {
	float: left;
}

.widget_price_filter .ui-slider {
	position: relative;
	text-align: left;
}

.widget_price_filter .ui-slider .ui-slider-handle {
	position: absolute;
	z-index: 2;
	width: 1em;
	height: 1em;
	cursor: ew-resize;
	outline: none;
	background: #4169e1;
	box-sizing: border-box;
	margin-top: -0.25em;
	opacity: 1;
}

.widget_price_filter .ui-slider .ui-slider-handle:last-child {
	margin-left: -1em;
}

.widget_price_filter .ui-slider .ui-slider-handle:hover,
.widget_price_filter .ui-slider .ui-slider-handle.ui-state-active {
	box-shadow: 0 0 0 0.25em rgba(0, 0, 0, 0.1);
}

.widget_price_filter .ui-slider .ui-slider-range {
	position: absolute;
	z-index: 1;
	display: block;
	border: 0;
	background: #4169e1;
}

.widget_price_filter .price_slider_wrapper .ui-widget-content {
	background: rgba(0, 0, 0, 0.1);
}

.widget_price_filter .ui-slider-horizontal {
	height: 0.5em;
}

.widget_price_filter .ui-slider-horizontal .ui-slider-range {
	height: 100%;
}

.woocommerce-LoopProduct-link.woocommerce-loop-product__link {
	text-decoration: none;
}

.woocommerce-loop-product__title {
	color: #000;
	font-family: "Parkinsans", sans-serif;
	font-size: 20px;
	font-style: normal;
	font-weight: 600;
	line-height: 20px;
	margin-top: 1rem;
	margin-bottom: 1rem;
}

.price {
	color: #000;
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 600;
	line-height: 20px;
	display: block;
	margin: 1rem 0px;
}

.yith-wcan-filters .yith-wcan-filter .filter-items .filter-item.active>a,
.yith-wcan-filters .yith-wcan-filter .filter-items .filter-item.active>label>a {
	color: var(--color-secondary) !important;
	font-family: "Parkinsans", sans-serif;
	font-size: 14px;
	font-style: normal;
	font-weight: 500;
	line-height: 20px;
}

li.product {
	border-radius: 20px;
	border: 1px solid #F8F9FA;
	box-shadow: 0 12px 16px 0 rgba(0, 0, 0, 0.05);
	padding: 20px;
}

.single_add_to_cart_button {
	color: var(--komypets-cream);
	font-family: "Parkinsans", sans-serif;
	font-size: 22px;
	font-style: normal;
	font-weight: 500;
	line-height: 18px;
	letter-spacing: 1px;
	width: 100%;
}

.yith-wcwl-add-to-wishlist-button__label {

	color: #000;
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 300;
	line-height: 18px;
	letter-spacing: 1px;
}

.label-tag {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
	letter-spacing: 0.78px;
}

.woo-variation-swatches .variable-items-wrapper {
	display: flex;
	flex-wrap: nowrap;
	gap: 16px;
	align-items: center;
}

/* .woo-variation-swatches .variable-items-wrapper .variable-item:not(.radio-variable-item) {
	margin: 0px !important;
	padding: 16px 24px;
	border-radius: 8px !important;
	border: 1px solid #000 !important;
} */

/* .woo-variation-swatches .wvs-style-squared.variable-items-wrapper .variable-item:not(.radio-variable-item).button-variable-item .variable-item-span {
	padding: 0px !important;
	color: #000 !important;
	text-align: center;
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 16px;
} */

.woo-selected-variation-item-name {
	display: none !important;
}

label[for="talla"] {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
	letter-spacing: 0.78px;
	display: block;
	margin-bottom: 2rem !important;
}

.woocommerce-product-details__short-description * {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 18px;
	font-style: normal;
	font-weight: 400;
	line-height: 28px;
	letter-spacing: 0.78px;
}

.woocommerce-product-details__short-description a {
	display: none !important;
}

.product_title.entry-title {
	align-self: stretch;
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 36px;
	font-style: normal;
	font-weight: 500;
	line-height: 50px;
	letter-spacing: 0.78px;
}

.price_custom {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 22px;
	font-style: normal;
	font-weight: 500;
	line-height: 28px;
	letter-spacing: 0.78px;
}

#showReviews {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: 24px;
	text-decoration: none;
	margin-left: 1rem;
}

/* 5 iconos exactos con separación fija */
.star-rating {
	--star: url('https://komypets.com/wp-content/uploads/2025/08/Huella-valotacion-full-200x200px-49.svg');
	/* ← tu SVG */
	--size: 25px;
	/* tamaño del icono */
	--gap: 6px;
	/* separación entre iconos */
	--empty: #d6d6d6;
	/* color vacías */
	--filled: #ffb400;
	/* color llenas */

	position: relative;
	display: inline-block;
	width: calc(5 * var(--size) + 4 * var(--gap));
	height: var(--size);
	font-size: 0;
}

/* fila de vacías */
.star-rating::before,
.star-rating>span::before {
	content: "";
	position: absolute;
	inset: 0;
	-webkit-mask-image: var(--star), var(--star), var(--star), var(--star), var(--star);
	mask-image: var(--star), var(--star), var(--star), var(--star), var(--star);
	-webkit-mask-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
	mask-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
	-webkit-mask-size: var(--size) var(--size);
	mask-size: var(--size) var(--size);
	/* posiciones x de cada icono (sin multiplicaciones para máxima compatibilidad) */
	-webkit-mask-position:
		0 50%,
		calc(var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap)) 50%;
	mask-position:
		0 50%,
		calc(var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap)) 50%,
		calc(var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap) + var(--size) + var(--gap)) 50%;
}

.star-rating::before {
	background: var(--empty);
}

/* el <span> de Woo define el % de relleno */
.star-rating>span {
	position: relative;
	display: block;
	height: 100%;
	overflow: hidden;
	/* recorta al % */
	white-space: nowrap;
	text-indent: -9999px;
	/* accesible pero oculto */
}

.star-rating>span::before {
	background: var(--filled);
}

/* anula las “★★★★★” por defecto */
.star-rating span::before {
	content: "" !important;
}

/* === Patitas en el formulario de valoración === */
p.stars {
	--paw: url('https://komypets.com/wp-content/uploads/2025/08/Huella-valotacion-full-200x200px-49.svg');
	/* ← pon aquí tu SVG */
	--size: 22px;
	/* tamaño del icono */
	--gap: 6px;
	/* separación entre iconos */
	--empty: #d6d6d6;
	/* color vacío */
	--filled: #ffb400;
	/* color lleno */
}

/* Cada "estrella" (ahora patita) */
p.stars a {
	position: relative;
	display: inline-block;
	width: var(--size);
	height: var(--size);
	margin-right: var(--gap);
	text-indent: -9999px;
	/* oculta el texto accesible */
	outline: none;
}

p.stars a:last-child {
	margin-right: 0;
}

/* Sustituye el icono por la máscara SVG */
p.stars a::before {
	content: "" !important;
	/* anula el \53 */
	font-family: inherit !important;
	/* quita la fuente "star" */
	position: absolute;
	inset: 0;
	background: var(--empty);
	-webkit-mask: var(--paw) center / contain no-repeat;
	mask: var(--paw) center / contain no-repeat;
	opacity: 1;
}

/* --- Interacciones --- */
/* Al pasar el ratón: llena todas y luego vacía las que van después de la hovered */
p.stars:hover a::before {
	background: var(--filled);
}

p.stars:hover a:hover~a::before {
	background: var(--empty);
}

/* Selección fija (WooCommerce añade .selected y marca el <a> elegido con .active) */
p.stars.selected a::before {
	background: var(--filled);
}

p.stars.selected a.active~a::before {
	background: var(--empty);
}

/* Accesibilidad visual al enfocar con teclado */
p.stars a:focus-visible {
	outline: 2px dotted currentColor;
	outline-offset: 2px;
}

.woocommerce-Reviews-title {
	font-family: "Parkinsans", sans-serif;
	font-size: 18px;
}

#accordionFlushExample .accordion-button,
.single-product .d-block.border-bottom.border-black {
	border-color: var(--komypets-cream) !important;
}

#accordionFlushExample .accordion-button {
	color: var(--color-secondary);
	font-family: "Parkinsans", sans-serif;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: normal;
	letter-spacing: 0.78px;
}

.accordion-button:focus {
	box-shadow: none !important;
}


.quantity {
	position: relative;
	display: inline-flex;
	align-items: center;
	height: 32px;
	padding: 0 36px;
	border: 1px solid #000;
	border-radius: 6px;
	background: #fff;
}

.quantity .qty {
	width: 100%;
	border: 0 !important;
	background: transparent;
	text-align: center;
	height: 30px;
	line-height: 30px;
	outline: none;
	z-index: 1;
}

.quantity .qty-btn {
	position: absolute;
	top: 0px;
	width: 28px;
	height: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0;
	background: transparent;
	cursor: pointer;
	z-index: 2;
	color: var(--color-secondary);
	font-size: 18px;
	line-height: 1;
	border-radius: 8px;
}

.quantity .qty-btn.minus {
	left: 2px;
}

.quantity .qty-btn.plus {
	right: 2px;
}

/* .quantity .qty-btn:hover {
	background: #f3f5f7;
} */

.quantity input[type=number]::-webkit-outer-spin-button,
.quantity input[type=number]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.quantity input[type=number] {
	-moz-appearance: textfield;
	appearance: textfield;
}

.title_related {
	color: var(--color-secondary);
	text-align: center;
	font-size: 64px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
}

body.woocommerce-shop .variable-item-span.variable-item-span-button {
	font-size: 14px !important;
	line-height: 1 !important;
}

.woo-variation-swatches .wvs-style-squared.variable-items-wrapper .variable-item:not(.radio-variable-item) {
	border-radius: 8px !important;
}

.wc-block-mini-cart__badge {
  align-items: center;
  border-radius: 1em;
  box-sizing: border-box;
  display: flex;
  font-size: 1em;
  font-weight: 600;
  height: 1rem;
  justify-content: center;
  left: 100%;
  margin-left: -44%;
  min-width: 1rem;
  padding: 0 .25em;
  position: absolute;
  transform: translateY(-50%);
  white-space: nowrap;
  z-index: 99;
  background: #EB5A43;
  color: white;
}