﻿:root {
	--bg: #f4eee5;
	--surface: #fffdf9;
	--surface-soft: #f6f1e8;
	--text: #18233e;
	--muted: #6b7488;
	--primary: #173e93;
	--primary-strong: #102d6d;
	--accent: #d49b2c;
	--border: #ded4c5;
	--danger: #cb2f2f;
	--success: #168d57;
	--radius-lg: 24px;
	--radius-md: 16px;
	--radius-sm: 10px;
	--shadow-sm: 0 10px 28px rgba(31, 37, 55, 0.08);
	--shadow-md: 0 18px 40px rgba(31, 37, 55, 0.12);
	--container: min(1200px, 94vw);
}

* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

body {
	font-family: 'Nunito Sans', 'Trebuchet MS', sans-serif;
	background: radial-gradient(circle at 14% -6%, #fbf4d5 0, transparent 26%),
		radial-gradient(circle at 86% -10%, #e8dfd2 0, transparent 32%),
		var(--bg);
	color: var(--text);
	line-height: 1.45;
}

a {
	color: inherit;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

.container {
	width: var(--container);
	margin: 0 auto;
}

.site-header {
	position: static;
	z-index: auto;
	margin-bottom: 14px;
	background: linear-gradient(180deg, #132849 0%, #172f5b 100%);
	padding-bottom: 8px;
}

.header-banner {
	padding: 14px 0 8px;
}

.header-banner-row {
	position: relative;
	width: 100%;
	padding: 0 18px;
	display: block;
}

.main-nav {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 560px) minmax(0, 1fr);
	align-items: center;
	gap: 14px;
	width: 100%;
}

.nav-toggle {
	display: none;
	width: 40px;
	height: 40px;
	padding: 0;
	border: 1px solid #7ea3ef;
	border-radius: 10px;
	background: linear-gradient(135deg, #1f63e0, #0d45ba);
	cursor: pointer;
	box-shadow: 0 8px 18px rgba(15, 60, 157, 0.3);
}

.nav-toggle span {
	display: block;
	width: 20px;
	height: 2px;
	margin: 4px auto;
	background: #ffffff;
	border-radius: 1px;
}

.nav-group {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 8px;
	min-width: 0;
}

.nav-left {
	justify-content: flex-end;
}

.nav-right {
	justify-content: flex-start;
}

.main-nav .nav-group > a,
.main-nav .nav-group .link-btn,
.main-nav .nav-group .categories-menu summary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	padding: 10px 13px;
	text-decoration: none;
	font-size: 0.76rem;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #edf3ff;
	border: 1px solid rgba(140, 167, 230, 0.8);
	border-radius: 999px;
	background: linear-gradient(135deg, #1b4bb0, #143d91);
	box-shadow: 0 12px 20px rgba(8, 21, 49, 0.28);
	cursor: pointer;
	transition: transform 0.16s ease, filter 0.16s ease, box-shadow 0.16s ease;
	white-space: nowrap;
	min-width: 96px;
}

.main-nav .nav-group > a:hover,
.main-nav .nav-group .link-btn:hover,
.main-nav .nav-group .categories-menu summary:hover {
	transform: translateY(-1px);
	filter: brightness(1.08);
	box-shadow: 0 12px 20px rgba(14, 60, 156, 0.3);
}

.main-nav .nav-group > a.is-active {
	background: linear-gradient(135deg, #e0b14a, #c78f1e);
	border-color: #f0cf8b;
	color: #231c10;
	box-shadow: 0 10px 20px rgba(114, 78, 20, 0.32);
}

.header-logo-link {
	display: block;
	text-decoration: none;
	border-radius: var(--radius-lg);
	border: 1px solid rgba(210, 195, 178, 0.65);
	box-shadow: var(--shadow-md);
	background: linear-gradient(180deg, rgba(249, 244, 236, 0.12), rgba(239, 230, 218, 0.12));
	padding: 6px;
}

.header-logo-link img {
	width: 100%;
	height: auto;
	max-height: 120px;
	object-fit: contain;
	object-position: center;
}

.cart-link {
	background: linear-gradient(135deg, #2858b8, #1d4698);
	border-color: rgba(132, 161, 224, 0.95);
	min-width: 114px;
}

.cart-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 21px;
	height: 21px;
	padding: 0 7px;
	margin-left: 2px;
	border-radius: 999px;
	font-size: 0.74rem;
	font-weight: 800;
	background: #ffffff;
	color: #1d4fbc;
}

.inline-form {
	margin: 0;
}

.link-btn {
	font: inherit;
}

.categories-menu {
	position: relative;
}

.categories-menu summary {
	list-style: none;
}

.categories-menu summary::-webkit-details-marker {
	display: none;
}

.categories-menu summary::after {
	content: '';
	width: 8px;
	height: 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg) translateY(-1px);
	transition: transform 0.2s ease;
}

.categories-menu[open] summary::after {
	transform: rotate(-135deg) translateY(-1px);
}

.categories-dropdown {
	position: absolute;
	top: calc(100% + 8px);
	left: 0;
	z-index: 30;
	min-width: 260px;
	max-height: 360px;
	overflow-y: auto;
	padding: 8px;
	display: grid;
	gap: 4px;
	background: #fff;
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
}

.account-menu .categories-dropdown {
	left: auto;
	right: 0;
	min-width: 200px;
}

.account-dropdown .inline-form {
	margin: 0;
	display: block;
}

.main-nav .account-dropdown .account-logout-btn {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	padding: 9px 10px;
	min-width: 0;
	border-radius: 8px;
	border: 1px solid var(--border);
	background: #ffffff;
	color: #1a315f;
	font-weight: 700;
	font-size: 0.9rem;
	text-transform: none;
	letter-spacing: 0;
	text-align: left;
	box-shadow: none;
}

.main-nav .account-dropdown .account-logout-btn:hover {
	transform: none;
	filter: none;
	background: #edf3ff;
	border-color: #cfdbf8;
	box-shadow: none;
}

.categories-dropdown a {
	display: block;
	padding: 9px 10px;
	text-decoration: none;
	border-radius: 8px;
	font-size: 0.92rem;
}

.categories-dropdown a:hover {
	background: #edf3ff;
}

.site-content {
	padding: 0 0 48px;
}

.card-surface,
.card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

.card {
	padding: 16px;
}

.hero {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: 18px;
	padding: 18px;
	margin-bottom: 22px;
}

.hero-copy {
	display: grid;
	align-content: start;
	gap: 10px;
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	margin: 0;
	padding: 5px 10px;
	border-radius: 999px;
	font-size: 0.74rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	background: #eaf1ff;
	color: var(--primary-strong);
}

.hero h1 {
	margin: 0;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: clamp(1.6rem, 2.5vw, 2.35rem);
	line-height: 1.12;
}

.hero p {
	margin: 0;
	color: var(--muted);
	font-size: 1rem;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 4px;
}

.hero-media {
	overflow: hidden;
	border-radius: 14px;
	border: 1px solid #c8d8fa;
	background: #dce9ff;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.hero-media img {
	width: 100%;
	height: 100%;
	max-height: 280px;
	object-fit: contain;
	background: #eff4ff;
}

.hero-stats {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 2px;
}

.hero-stats div {
	padding: 12px;
	border: 1px solid #d7e3fb;
	border-radius: 12px;
	background: linear-gradient(160deg, #f7faff, #eef4ff);
}

.hero-stats strong {
	display: block;
	font-size: 1.45rem;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	color: var(--primary-strong);
}

.hero-stats span {
	display: block;
	font-size: 0.88rem;
	font-weight: 700;
	color: #42557f;
}

.section-block {
	margin-bottom: 22px;
}

.section-title-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 12px;
}

.section-title-row h2 {
	margin: 0;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: 1.4rem;
}

.section-title-row a {
	text-decoration: none;
	color: var(--primary-strong);
	font-weight: 800;
}

.category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
	gap: 12px;
}

.category-tile {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-decoration: none;
	padding: 15px;
	height: 100%;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.category-tile h3 {
	margin: 0;
	font-size: 1rem;
	line-height: 1.25;
}

.category-tile p {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.45;
	color: var(--muted);
	flex: 1;
}

.category-tile span {
	font-size: 0.84rem;
	font-weight: 800;
	color: var(--primary-strong);
}

.category-tile:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.catalog-head {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding: 10px 14px;
	margin-bottom: 12px;
}

.catalog-count {
	margin: 0;
	padding: 8px 12px;
	border-radius: 10px;
	font-size: 0.95rem;
	font-weight: 800;
	background: #edf4ff;
	color: #244b9e;
	border: 1px solid #d2e0fb;
}

.filter-panel {
	padding: 14px;
	margin-bottom: 14px;
	position: sticky;
	top: 8px;
	z-index: 24;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(8px);
}

.catalog-filters {
	display: grid;
	grid-template-columns: minmax(260px, 1.2fr) 1px minmax(220px, 0.8fr) auto;
	gap: 10px;
	align-items: end;
}

.filters-block {
	display: grid;
	gap: 6px;
}

.filters-block label {
	font-size: 0.85rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: #3f4f72;
}

.search-inline {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 8px;
}

.search-inline .btn {
	height: 40px;
	padding-inline: 16px;
}

.filters-divider {
	width: 1px;
	height: 42px;
	align-self: end;
	background: linear-gradient(180deg, transparent 0%, #cad8f5 18%, #cad8f5 82%, transparent 100%);
}

.filter-actions {
	display: inline-flex;
	justify-content: flex-end;
	gap: 8px;
	flex-wrap: wrap;
}

.product-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
	gap: 10px;
	align-items: stretch;
}

.product-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	position: relative;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	background: linear-gradient(180deg, #fffefb, #f5f9ff);
	border-color: #d7e3fb;
}

.product-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 20px 42px rgba(31, 54, 96, 0.12);
	border-color: #bfd0f7;
}

.product-card.in-cart {
	border-color: #7ea3ef;
	box-shadow: 0 0 0 2px rgba(31, 99, 224, 0.16), 0 20px 42px rgba(31, 54, 96, 0.12);
}

.product-card.out-of-stock {
	border-color: #e7b8b8;
}

.card-cart-mark {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 2;
	width: 28px;
	height: 28px;
	border-radius: 999px;
	display: none;
	align-items: center;
	justify-content: center;
	font-size: 0.9rem;
	background: #e7f0ff;
	border: 1px solid #b7cdf9;
	color: #31579f;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.16s ease, box-shadow 0.16s ease;
}

.card-cart-mark:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 10px rgba(35, 80, 160, 0.18);
}

.product-card.in-cart .card-cart-mark {
	display: inline-flex;
}

.offer-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	z-index: 3;
	padding: 5px 8px;
	border-radius: 999px;
	font-size: 0.68rem;
	font-weight: 900;
	letter-spacing: 0.05em;
	background: linear-gradient(135deg, #f7be3d, #d79b16);
	color: #1f2f52;
	border: 1px solid #e2b425;
}

.stock-ribbon {
	position: absolute;
	left: 0;
	right: 0;
	top: 46%;
	z-index: 3;
	padding: 7px 10px;
	text-align: center;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	background: rgba(175, 35, 35, 0.92);
	color: #fff;
	border-top: 1px solid rgba(255, 255, 255, 0.45);
	border-bottom: 1px solid rgba(255, 255, 255, 0.45);
	pointer-events: none;
}

.product-image {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: #edf2fb;
	border-bottom: 1px solid #d8e3fb;
}

.product-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 10px;
	transition: transform 0.22s ease, opacity 0.22s ease;
}

.product-image::after {
	content: 'Más detalles';
	position: absolute;
	left: 50%;
	top: 14px;
	transform: translateX(-50%) translateY(-6px);
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(18, 33, 66, 0.88);
	color: #fff;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.18s ease, transform 0.18s ease;
}

.product-card:hover .product-image::after {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

.product-card:hover .product-image img {
	transform: scale(1.02);
}

.image-placeholder {
	display: grid;
	place-items: center;
	height: 100%;
	padding: 10px;
	color: #6b7894;
	font-weight: 700;
}

.image-placeholder.large {
	min-height: 340px;
}

.product-body {
	display: flex;
	flex-direction: column;
	gap: 7px;
	padding: 13px 13px 10px;
	flex: 1;
}

.product-category {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #244b9e;
}

.product-body h3 {
	margin: 0;
	font-size: 1rem;
	line-height: 1.33;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 2.66em;
}

.product-body h3 a {
	text-decoration: none;
}

.price {
	margin: auto 0 0;
	font-size: 1.14rem;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-weight: 800;
	color: #0f1f44;
}

.price-group {
	display: grid;
	gap: 2px;
	margin-top: auto;
}

.price-original {
	margin: 0;
	font-size: 0.86rem;
	font-family: 'Nunito Sans', 'Trebuchet MS', sans-serif;
	font-weight: 700;
	color: #6a7895;
	text-decoration: line-through;
}

.price-offer {
	margin: 0;
	color: #c0382f;
}

.price-group-detail .price-original {
	font-size: 0.95rem;
}

.price.large {
	font-size: 1.55rem;
	margin: 0 0 8px;
}

.product-actions {
	display: block;
	padding: 0 13px 13px;
}

.product-actions form {
	margin: 0;
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 8px;
	align-items: end;
}

.qty-inline {
	display: grid;
	gap: 4px;
}

.qty-inline label {
	font-size: 0.75rem;
	font-weight: 800;
	color: #3f4f72;
}

.qty-input {
	height: 34px;
	padding: 6px 8px;
	text-align: center;
	border-radius: 8px;
}

.add-cart-btn {
	width: 100%;
	height: 34px;
	gap: 6px;
}

.btn-icon {
	font-size: 0.95rem;
	line-height: 1;
}

.in-cart-badge {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	visibility: hidden;
	min-height: 32px;
	margin: 0 13px 13px;
	padding: 7px 9px;
	border-radius: 9px;
	font-size: 0.8rem;
	font-weight: 700;
	color: #244b9e;
	background: #edf4ff;
	border: 1px solid #cfe0ff;
}

.product-card.in-cart .in-cart-badge {
	visibility: visible;
}

.in-cart-badge form {
	margin: 0;
}

.badge-cancel-btn {
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	border: 1px solid #9ab8ef;
	background: #fff;
	color: #31579f;
	font-size: 0.75rem;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
	padding: 0;
}

.badge-cancel-btn:hover {
	background: #eaf1ff;
}

.product-view {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

.product-media,
.product-detail {
	padding: 16px;
}

.product-media img {
	width: 100%;
	max-height: 540px;
	object-fit: contain;
	background: #f4f8ff;
	border: 1px solid var(--border);
	border-radius: 12px;
}

.product-detail h1 {
	margin: 0 0 10px;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: clamp(1.45rem, 2.3vw, 2.1rem);
}

.stock-chip {
	display: inline-flex;
	margin-bottom: 12px;
	padding: 7px 11px;
	border-radius: 999px;
	font-size: 0.84rem;
	font-weight: 700;
}

.stock-chip.in {
	background: #e7f7ee;
	color: #196e44;
}

.stock-chip.out {
	background: #fdeaea;
	color: #9a2020;
}

.product-description {
	margin-bottom: 14px;
	line-height: 1.6;
	color: #33435f;
}

.add-cart-form {
	display: grid;
	grid-template-columns: 120px auto;
	gap: 10px;
	align-items: end;
	margin-bottom: 10px;
}

.add-cart-form label {
	grid-column: 1 / -1;
	font-size: 0.9rem;
	font-weight: 700;
}

.cart-layout {
	display: grid;
	grid-template-columns: 1.5fr 0.8fr;
	gap: 12px;
}

.cart-items {
	padding: 12px;
}

.cart-item {
	display: grid;
	grid-template-columns: 86px 1fr auto;
	align-items: center;
	gap: 10px;
	padding: 12px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: #fafcff;
}

.cart-item + .cart-item {
	margin-top: 10px;
}

.cart-item-media {
	width: 86px;
	height: 86px;
	overflow: hidden;
	border-radius: 8px;
	background: #f3f6fc;
}

.cart-item-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cart-item-info h3 {
	margin: 0 0 4px;
	font-size: 1rem;
}

.muted {
	margin: 0;
	color: var(--muted);
}

.line-total {
	margin: 5px 0 0;
	font-weight: 700;
}

.cart-item-actions {
	display: grid;
	gap: 8px;
	justify-items: end;
}

.qty-form {
	display: flex;
	align-items: center;
	gap: 8px;
}

.qty-form input {
	width: 72px;
}

.cart-summary {
	padding: 16px;
	height: fit-content;
}

.summary-line {
	display: flex;
	justify-content: space-between;
	padding: 9px 0;
	margin: 0;
	border-bottom: 1px solid var(--border);
}

.summary-help {
	margin-top: 10px;
	font-size: 0.87rem;
	line-height: 1.5;
	color: var(--muted);
}

.auth-layout {
	display: grid;
	place-items: center;
	padding: 20px 0;
}

.auth-card {
	width: min(500px, 100%);
	padding: 20px;
}

.auth-card h1 {
	margin: 0 0 8px;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
}

.auth-card p {
	margin: 0 0 12px;
	color: var(--muted);
}

input,
select,
textarea,
button {
	font: inherit;
}

input,
select,
textarea {
	width: 100%;
	padding: 10px 11px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: #fff;
	color: var(--text);
}

input:focus,
select:focus,
textarea:focus {
	outline: none;
	border-color: #8ca9e8;
	box-shadow: 0 0 0 3px rgba(15, 87, 217, 0.12);
}

.form-grid {
	display: grid;
	gap: 9px;
}

.field-wide {
	grid-column: 1 / -1;
}

.help-text {
	margin: 0;
	font-size: 0.8rem;
	color: #667795;
}

.admin-product-form {
	gap: 12px;
}

.admin-form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px 12px;
}

.new-category-fields {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px 12px;
	padding: 10px;
	border: 1px dashed #cbd9f7;
	border-radius: 10px;
	background: #f7faff;
}

.image-preview-label {
	margin: 0 0 6px;
	font-size: 0.82rem;
	font-weight: 800;
	color: #3f4f72;
}

.admin-image-preview-wrap {
	display: grid;
	place-items: center;
	min-height: 200px;
	border: 1px dashed #ccd8f0;
	border-radius: 12px;
	background: #f8fbff;
	overflow: hidden;
}

.admin-image-preview {
	width: 100%;
	max-height: 280px;
	object-fit: contain;
}

.admin-image-placeholder {
	font-weight: 700;
	color: #60708c;
}

.offer-pill {
	display: inline-flex;
	padding: 3px 7px;
	border-radius: 999px;
	font-size: 0.78rem;
	font-weight: 800;
	background: #ffefbb;
	color: #6f4d00;
	border: 1px solid #f3d783;
}

.inline-form {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 14px;
	border-radius: 10px;
	border: 1px solid transparent;
	text-decoration: none;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
	transition: transform 0.14s ease, box-shadow 0.14s ease, filter 0.14s ease;
}

.btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 16px rgba(9, 25, 59, 0.12);
}

.btn:active {
	transform: translateY(0);
}

.btn[disabled] {
	opacity: 0.6;
	cursor: not-allowed;
	box-shadow: none;
}

.btn-sm {
	padding: 8px 10px;
	font-size: 0.85rem;
}

.btn-primary {
	background: linear-gradient(135deg, #1c64e2, #0b47bf);
	color: #fff;
	border-color: #0b47bf;
}

.btn-soft {
	background: #edf3ff;
	color: #22468f;
	border-color: #cfddff;
}

.btn-danger {
	background: var(--danger);
	color: #fff;
	border-color: #af2929;
}

.alert {
	margin-bottom: 12px;
	padding: 11px 13px;
	border-radius: 10px;
	font-weight: 700;
	border: 1px solid transparent;
}

.alert-success {
	background: #e7f8ee;
	border-color: #bce8cd;
	color: #1c6d45;
}

.alert-error {
	background: #fdecec;
	border-color: #f4c5c5;
	color: #9a2020;
}

.empty-state {
	padding: 22px;
	text-align: center;
}

.is-hidden {
	display: none !important;
}

/* Mantener ocultacion funcional cuando hay reglas display !important en cards */
#catalogGrid .product-card.is-hidden,
#catalogGrid [data-product-card].is-hidden {
	display: none !important;
}

.section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

.section-header h1 {
	margin: 0;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
}

.section-header p {
	margin: 0;
	color: var(--muted);
}

.grid {
	display: grid;
	gap: 12px;
}

.grid-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.checkbox-line {
	display: flex;
	align-items: center;
	gap: 8px;
}

.checkbox-line input[type='checkbox'] {
	width: auto;
}

.table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.93rem;
}

.table th,
.table td {
	padding: 10px 8px;
	border-bottom: 1px solid var(--border);
	text-align: left;
	vertical-align: middle;
}

.table th {
	background: #f4f7fc;
}

.admin-products-table th {
	white-space: nowrap;
}

.admin-products-table {
	table-layout: fixed;
	width: 100%;
}

.admin-products-table .col-id {
	width: 58px;
}

.admin-products-table .col-thumb {
	width: 74px;
}

.admin-products-table .col-name {
	width: 50ch;
}

.admin-products-table .col-category {
	width: 23ch;
}

.admin-products-table .col-price,
.admin-products-table .col-offer {
	width: 12ch;
}

.admin-products-table .col-active {
	width: 10ch;
}

.admin-products-table .col-actions {
	width: 220px;
}

.admin-products-table td {
	vertical-align: middle;
}

.admin-products-table .admin-inline-field {
	width: 100%;
	min-width: 0;
}

.admin-products-table .cell-name .admin-inline-field {
	min-width: 38ch;
}

.admin-products-table td {
	min-width: 0;
	overflow: hidden;
}

.admin-products-table td.cell-category {
	position: relative;
	overflow: visible;
}

.admin-inline-field {
	width: 100%;
	min-width: 0;
	height: 34px;
	padding: 6px 8px;
	font-size: 0.86rem;
	border-radius: 8px;
}

.cell-id {
	text-align: center;
	font-weight: 800;
}

.cell-thumb {
	text-align: center;
}

.admin-product-thumb {
	display: block;
	width: 46px;
	height: 46px;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid #c3d6f6;
	background: #fff;
	margin: 0 auto;
}

.admin-product-thumb-placeholder {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.62rem;
	font-weight: 900;
	letter-spacing: 0.03em;
	color: #6b7fa7;
	background: #edf3ff;
}

.cell-name .admin-inline-name {
	min-width: 50ch;
}

.admin-row-category-picker {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 34px;
	gap: 6px;
	margin-bottom: 6px;
}

.admin-row-category-reset {
	min-width: 34px;
	height: 34px;
	padding: 0;
	font-size: 1.08rem;
	font-weight: 900;
	line-height: 1;
}

.admin-inline-category-select {
	display: none !important;
}

.admin-row-category-results {
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	right: 0;
	display: grid;
	gap: 4px;
	max-height: 196px;
	overflow-y: auto;
	padding: 6px;
	border-radius: 10px;
	border: 1px solid #bfd5f7;
	background: #ffffff;
	box-shadow: 0 14px 24px rgba(16, 44, 99, 0.18);
	z-index: 72;
}

.admin-row-category-option {
	width: 100%;
	text-align: left;
	border: 1px solid #d6e3f9;
	background: #f7faff;
	color: #1d4a96;
	border-radius: 8px;
	padding: 7px 9px;
	font-size: 0.84rem;
	font-weight: 700;
	cursor: pointer;
}

.admin-row-category-option:hover,
.admin-row-category-option:focus-visible {
	background: #ebf3ff;
	border-color: #9ebae9;
	outline: none;
}

.admin-actions-cell {
	min-width: 0 !important;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 5px;
}

.admin-actions-cell .inline-form {
	display: inline-flex;
}

.icon-btn {
	width: 32px;
	height: 32px;
	padding: 0;
	border-radius: 9px;
}

.icon-btn span {
	font-size: 0.92rem;
	line-height: 1;
}

.quick-edit-state {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	padding: 4px 8px;
	border-radius: 999px;
	font-size: 0.76rem;
	font-weight: 800;
	letter-spacing: 0.02em;
	color: #6b7894;
	background: #eef3fd;
	border: 1px solid #d6e1f7;
}

.quick-edit-state:empty {
	display: none;
}

.quick-edit-state.is-dirty {
	color: #8a5a00;
	background: #fff7de;
	border-color: #ecd28a;
}

.quick-edit-state.is-saving {
	color: #244b9e;
	background: #e9f1ff;
	border-color: #c3d7ff;
}

.quick-edit-state.is-success {
	color: #176844;
	background: #e8f7ef;
	border-color: #bde6ce;
}

.quick-edit-state.is-error {
	color: #972a2a;
	background: #fdecec;
	border-color: #f2c2c2;
}

[data-admin-product-row].is-dirty td {
	background: #fffdf6;
}

[data-admin-product-row].is-saving {
	opacity: 0.72;
}

.big-number {
	font-size: 2rem;
	font-weight: 900;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	margin: 8px 0 12px;
}

.site-footer {
	position: relative;
	background: radial-gradient(circle at 12% 8%, rgba(48, 98, 209, 0.35) 0, transparent 36%),
		radial-gradient(circle at 88% 92%, rgba(23, 181, 140, 0.2) 0, transparent 42%),
		linear-gradient(160deg, #0b1530 0%, #14264b 100%);
	color: #d8e5ff;
	padding: 20px 0 8px;
	border-top: 1px solid rgba(141, 169, 229, 0.26);
}

.footer-legacy-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	position: relative;
	z-index: 1;
}

.footer-block {
	padding: 10px;
	border-radius: 10px;
	border: 1px solid rgba(169, 191, 235, 0.22);
	background: rgba(255, 255, 255, 0.04);
	backdrop-filter: blur(1px);
}

.footer-block h4 {
	margin: 0 0 6px;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: 0.93rem;
	color: #ffffff;
}

.footer-contact-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 6px;
}

.footer-contact-list li {
	display: grid;
	grid-template-columns: 18px 1fr;
	gap: 6px;
	font-size: 0.82rem;
	line-height: 1.35;
	color: #d7e3fb;
}

.footer-icon {
	display: inline-flex;
	align-items: flex-start;
	justify-content: center;
	color: #f7c84a;
	font-size: 0.95rem;
	line-height: 1.2;
}

.footer-map-wrap {
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid rgba(185, 205, 243, 0.32);
	background: #0b1630;
	min-height: 0;
}

.footer-map-wrap iframe {
	display: block;
	width: 100%;
	height: 150px;
	border: 0;
}

.footer-cta p {
	margin: 0 0 8px;
	font-size: 0.83rem;
	line-height: 1.3;
	color: #d7e3fb;
}

.footer-whatsapp-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 11px;
	border-radius: 10px;
	border: 1px solid #15975f;
	background: linear-gradient(135deg, #1bbf75, #12945b);
	color: #ffffff;
	font-weight: 800;
	font-size: 0.84rem;
	text-decoration: none;
	transition: transform 0.16s ease, box-shadow 0.16s ease, filter 0.16s ease;
}

.wa-icon {
	font-size: 0.96rem;
	line-height: 1;
}

.footer-whatsapp-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 18px rgba(13, 86, 54, 0.35);
	filter: brightness(1.05);
}

.footer-copy {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid rgba(181, 203, 245, 0.25);
	text-align: center;
	font-size: 0.8rem;
	color: #c6d6f7;
}

.btn-primary {
	background: linear-gradient(135deg, #173e93, #2953ab);
	color: #fff;
	border-color: #173e93;
}

.btn-soft {
	background: #f3ebdf;
	color: #213762;
	border-color: #d8c8b0;
}

.site-header {
	margin-bottom: 14px;
	background: linear-gradient(180deg, #132849 0%, #172f5b 100%);
	padding-bottom: 8px;
}

.header-banner {
	padding: 14px 0 8px;
}

.main-nav {
	gap: 14px;
}

.nav-toggle {
	border-color: #3f5a9d;
	border-radius: 12px;
	background: linear-gradient(135deg, #173e93, #244a9d);
	box-shadow: 0 10px 18px rgba(21, 42, 88, 0.28);
}

.main-nav .nav-group > a,
.main-nav .nav-group .link-btn,
.main-nav .nav-group .categories-menu summary {
	color: #edf3ff;
	border-color: rgba(140, 167, 230, 0.8);
	background: linear-gradient(135deg, #1b4bb0, #143d91);
	box-shadow: 0 12px 20px rgba(8, 21, 49, 0.28);
}

.main-nav .nav-group > a.is-active,
.main-nav .nav-group .categories-menu summary.is-active {
	background: linear-gradient(135deg, #e0b14a, #c78f1e);
	border-color: #f0cf8b;
	color: #231c10;
	box-shadow: 0 10px 20px rgba(114, 78, 20, 0.32);
}

.header-logo-link {
	border-color: rgba(210, 195, 178, 0.65);
	background: linear-gradient(180deg, rgba(249, 244, 236, 0.12), rgba(239, 230, 218, 0.12));
	padding: 6px;
}

.header-logo-link img {
	max-height: 120px;
}

.cart-link {
	background: linear-gradient(135deg, #2858b8, #1d4698);
	border-color: rgba(132, 161, 224, 0.95);
}

.cart-pill {
	background: #f7ecd9;
	color: #153776;
}

.categories-dropdown {
	background: #fffcf7;
	border-color: #ddd1c2;
}

.categories-dropdown a:hover {
	background: #f3ece2;
}

.catalog-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
	gap: 22px;
	padding: 28px;
	margin-bottom: 18px;
	background:
		linear-gradient(135deg, rgba(20, 39, 79, 0.98), rgba(23, 62, 147, 0.94)),
		linear-gradient(180deg, #183a8a, #274fa3);
	border-color: #24385e;
	color: #f7f2e8;
	overflow: hidden;
	position: relative;
}

.catalog-hero::before {
	content: '';
	position: absolute;
	inset: auto -120px -120px auto;
	width: 340px;
	height: 340px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(212, 155, 44, 0.38) 0%, rgba(212, 155, 44, 0) 72%);
}

.catalog-hero-copy,
.catalog-hero-panel {
	position: relative;
	z-index: 1;
}

.catalog-kicker {
	margin: 0 0 10px;
	font-size: 0.8rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #d9b56c;
}

.catalog-hero h1 {
	margin: 0 0 12px;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: clamp(2rem, 3.2vw, 3rem);
	line-height: 1.05;
	max-width: 12ch;
}

.catalog-hero-text {
	margin: 0;
	max-width: 56ch;
	font-size: 1rem;
	line-height: 1.6;
	color: rgba(244, 239, 231, 0.84);
}

.catalog-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

.catalog-hero-panel {
	display: grid;
	gap: 12px;
	align-content: start;
}

.catalog-hero-stat {
	padding: 16px 18px;
	border-radius: 18px;
	background: rgba(255, 250, 241, 0.08);
	border: 1px solid rgba(231, 212, 183, 0.18);
}

.catalog-hero-stat strong {
	display: block;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: 2rem;
	line-height: 1;
	color: #ffffff;
}

.catalog-hero-stat span {
	display: block;
	margin-top: 6px;
	font-size: 0.92rem;
	color: rgba(244, 239, 231, 0.82);
}

.catalog-hero-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.catalog-tag {
	display: inline-flex;
	align-items: center;
	padding: 9px 14px;
	border-radius: 999px;
	text-decoration: none;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #f5efe4;
	background: rgba(255, 250, 241, 0.08);
	border: 1px solid rgba(231, 212, 183, 0.18);
}

.catalog-tag:hover {
	background: rgba(255, 250, 241, 0.16);
}

.catalog-head {
	background: #f7f1e8;
}

.catalog-count {
	background: #eee4d7;
	color: #3f4f6f;
	border-color: #d8cbbc;
}

.filter-panel {
	padding: 16px;
	top: 10px;
	background: rgba(255, 251, 245, 0.95);
	backdrop-filter: blur(10px);
	border-color: #d9cdbd;
	box-shadow: 0 16px 30px rgba(49, 45, 42, 0.08);
}

.filters-block label,
.qty-inline label {
	color: #59657c;
}

.filters-divider {
	background: linear-gradient(180deg, transparent 0%, #dbcdbd 18%, #dbcdbd 82%, transparent 100%);
}

.product-grid {
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 18px;
}

.product-card {
	transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
	background: linear-gradient(180deg, #fffefb, #f5f9ff);
	border-color: #d7e3fb;
}

.product-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 20px 42px rgba(31, 54, 96, 0.12);
	border-color: #bfd0f7;
}

.product-card.in-cart {
	border-color: #7ea3ef;
	box-shadow: 0 0 0 2px rgba(31, 99, 224, 0.16), 0 20px 42px rgba(31, 54, 96, 0.12);
}

.card-cart-mark {
	background: #e7f0ff;
	border-color: #b7cdf9;
	color: #31579f;
}

.offer-badge {
	background: linear-gradient(135deg, #f7be3d, #d79b16);
	color: #1f2f52;
	border: 1px solid #e2b425;
}

.product-image {
	background: #edf2fb;
	border-bottom-color: #d8e3fb;
}

.product-image img {
	padding: 10px;
}

.product-category {
	color: #244b9e;
}

.price {
	color: #0f1f44;
}

.price-original {
	color: #6a7895;
}

.price-offer {
	color: #c0382f;
}

.in-cart-badge {
	color: #244b9e;
	background: #edf4ff;
	border-color: #cfe0ff;
}

.badge-cancel-btn {
	border-color: #9ab8ef;
	background: #fff;
	color: #31579f;
}

.badge-cancel-btn:hover {
	background: #eaf1ff;
}

.site-footer {
	background:
		radial-gradient(circle at 12% 8%, rgba(212, 155, 44, 0.16) 0, transparent 30%),
		radial-gradient(circle at 88% 92%, rgba(255, 255, 255, 0.08) 0, transparent 36%),
		linear-gradient(160deg, #16233f 0%, #223255 100%);
	color: #ece2d4;
	border-top-color: rgba(202, 174, 124, 0.28);
}

.footer-block {
	border-color: rgba(199, 176, 136, 0.24);
	background: rgba(255, 249, 241, 0.05);
}

.footer-contact-list li,
.footer-cta p,
.footer-copy {
	color: #e5d9cb;
}

.footer-icon {
	color: #d6a541;
}

.footer-map-wrap {
	border-color: rgba(199, 176, 136, 0.28);
	background: #10203d;
}

.footer-whatsapp-btn {
	border-color: #b5862a;
	background: linear-gradient(135deg, #d2a044, #bb8521);
	color: #231c10;
}

.footer-whatsapp-btn:hover {
	box-shadow: 0 10px 18px rgba(120, 82, 24, 0.34);
}

@keyframes fade-up {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.hero,
.catalog-head,
.filter-panel,
.category-tile,
.product-card {
	animation: fade-up 0.36s ease both;
}

@media (max-width: 1120px) {
	.catalog-hero {
		grid-template-columns: 1fr;
	}

	.catalog-filters {
		grid-template-columns: 1fr 1fr;
	}

	.search-block {
		grid-column: 1 / -1;
	}

	.filters-divider {
		display: none;
	}

	.filter-actions {
		grid-column: 1 / -1;
		justify-content: flex-start;
	}
}

@media (max-width: 940px) {
	.site-header {
		margin-bottom: 10px;
	}

	.header-banner {
		padding: 12px 0 6px;
	}

	.header-banner-row {
		position: relative;
	}

	.header-logo-link {
		padding: 6px;
	}

	.header-logo-link img {
		max-height: 96px;
	}

	.nav-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 40px;
		height: 40px;
		position: absolute;
		top: 8px;
		right: 8px;
		z-index: 6;
	}

	.main-nav {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.catalog-hero {
		padding: 22px;
	}

	.catalog-hero h1 {
		max-width: none;
	}

	.nav-group {
		display: none;
	}

	.main-nav.is-open .nav-group {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px;
	}

	.main-nav.is-open .nav-right {
		justify-content: stretch;
		padding-top: 8px;
		border-top: 1px solid #e4ebfa;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		width: 100%;
		justify-content: center;
		min-height: 38px;
		padding: 8px 10px;
		font-size: 0.74rem;
	}

	.nav-group .inline-form {
		width: 100%;
	}

	.nav-group .inline-form .link-btn {
		width: 100%;
	}

	.categories-dropdown {
		position: static;
		min-width: 0;
		margin-top: 6px;
	}

	.hero,
	.product-view,
	.cart-layout {
		grid-template-columns: 1fr;
	}

	.hero-media img {
		max-height: 240px;
	}

	.grid-3,
	.grid-4,
	.footer-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.footer-legacy-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.footer-legacy-grid .footer-block:nth-child(2) {
		grid-column: 1 / -1;
	}

	.footer-map-wrap iframe {
		height: 138px;
	}
}

@media (max-width: 680px) {
	.site-header {
		margin-bottom: 8px;
	}

	.header-banner {
		padding: 10px 0 5px;
	}

	.header-logo-link {
		padding: 5px;
		border-radius: 12px;
	}

	.header-logo-link img {
		max-height: 78px;
	}

	.site-content {
		padding-bottom: 36px;
	}

	.nav-toggle {
		width: 36px;
		height: 36px;
		top: 6px;
		right: 6px;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		min-height: 36px;
		font-size: 0.72rem;
		letter-spacing: 0.04em;
	}

	.catalog-hero {
		padding: 18px;
		gap: 16px;
	}

	.catalog-kicker {
		font-size: 0.74rem;
	}

	.catalog-hero h1 {
		font-size: 1.8rem;
	}

	.catalog-hero-text {
		font-size: 0.94rem;
	}

	.catalog-hero-actions {
		flex-direction: column;
	}

	.catalog-hero-actions .btn {
		width: 100%;
	}

	.catalog-hero-stat strong {
		font-size: 1.7rem;
	}

	.main-nav.is-open .nav-group {
		grid-template-columns: 1fr;
	}

	.main-nav.is-open .nav-right {
		padding-top: 6px;
	}

	.catalog-head,
	.section-title-row,
	.section-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.catalog-filters {
		grid-template-columns: 1fr;
	}

	.search-inline {
		grid-template-columns: 1fr;
	}

	.admin-form-grid,
	.new-category-fields {
		grid-template-columns: 1fr;
	}

	.product-grid,
	.category-grid,
	.grid-3,
	.grid-4,
	.footer-grid,
	.footer-legacy-grid {
		grid-template-columns: 1fr;
	}

	.site-footer {
		padding: 16px 0 8px;
	}

	.footer-legacy-grid {
		gap: 8px;
	}

	.footer-block {
		padding: 9px;
	}

	.footer-map-wrap iframe {
		height: 132px;
	}

	.footer-contact-list li {
		font-size: 0.8rem;
	}

	.footer-whatsapp-btn {
		width: 100%;
		justify-content: center;
	}

	.footer-copy {
		font-size: 0.76rem;
	}

	.product-actions {
		display: block;
	}

	.product-actions form {
		grid-template-columns: 68px 1fr;
	}

	.hero-stats {
		grid-template-columns: 1fr;
	}

	.cart-item {
		grid-template-columns: 1fr;
	}

	.cart-item-media {
		width: 100%;
		height: 180px;
	}

	.cart-item-actions {
		justify-items: stretch;
	}

	.qty-form {
		width: 100%;
	}

	.qty-form input {
		width: 100%;
	}

	.table {
		display: block;
		overflow-x: auto;
		white-space: nowrap;
	}
}

@media (max-width: 420px) {
	.header-banner img {
		max-height: 74px;
	}

	.catalog-hero {
		padding: 16px;
	}

	.catalog-hero h1 {
		font-size: 1.55rem;
	}

	.catalog-tag {
		width: 100%;
		justify-content: center;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		font-size: 0.7rem;
	}

	.footer-block h4 {
		font-size: 0.86rem;
	}

	.footer-contact-list li {
		grid-template-columns: 16px 1fr;
		font-size: 0.78rem;
	}

	.footer-map-wrap iframe {
		height: 120px;
	}
}

/* ===== Visual Refresh Final (blanco + azul) ===== */
:root {
	--bg: #eef3fb;
	--surface: #ffffff;
	--surface-soft: #f6f9ff;
	--text: #12213f;
	--muted: #5f6f8e;
	--primary: #1f63e0;
	--primary-strong: #1346ad;
	--accent: #1f63e0;
	--border: #d6e2f8;

	/* Cornflower Blue palette */
	--cf-50: #f0f6fe;
	--cf-100: #deeafb;
	--cf-200: #c5dbf8;
	--cf-300: #9dc4f3;
	--cf-400: #629dea;
	--cf-500: #4c84e5;
	--cf-600: #3767d9;
	--cf-700: #2e54c7;
	--cf-800: #2c46a1;
	--cf-900: #283e80;
	--cf-950: #1d284e;
}

body {
	background: radial-gradient(circle at 12% -12%, #ffffff 0, transparent 38%),
		radial-gradient(circle at 92% -14%, #dde8fb 0, transparent 36%),
		linear-gradient(180deg, #eef3fb 0%, #f8fbff 100%);
	color: var(--text);
}

.card-surface {
	background: #ffffff;
	border: 1px solid #d6e2f8;
	box-shadow: 0 10px 26px rgba(18, 45, 92, 0.08);
}

.site-header {
	margin-bottom: 12px;
	padding: 8px 0 12px;
	background: linear-gradient(180deg, #06255f 0%, #0d377f 100%);
}

.header-banner {
	padding: 0;
}

.header-banner-row {
	padding: 0;
}

.main-nav {
	position: relative;
	display: block;
	width: 100%;
}

.header-logo-link {
	display: block;
	width: 100%;
	padding: 0;
	border-radius: 24px;
	overflow: hidden;
	background: #052364;
	border: 1px solid #7fa5e8;
	box-shadow: 0 20px 40px rgba(7, 24, 63, 0.36);
}

.header-logo-link img {
	width: 100%;
	max-height: 220px;
	height: auto;
	object-fit: contain;
	object-position: center;
}

.nav-group {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	gap: 10px;
	z-index: 6;
}

.nav-left {
	left: clamp(10px, 1.8vw, 28px);
	justify-content: flex-start;
}

.nav-right {
	right: clamp(10px, 1.8vw, 28px);
	justify-content: flex-end;
}

.main-nav .nav-group > a,
.main-nav .nav-group .link-btn,
.main-nav .nav-group .categories-menu summary {
	min-width: 96px;
	padding: 10px 12px;
	border-radius: 999px;
	border: 1px solid rgba(163, 193, 248, 0.9);
	background: rgba(7, 38, 105, 0.8);
	color: #f7fbff;
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	backdrop-filter: blur(2px);
	box-shadow: 0 10px 22px rgba(9, 29, 78, 0.25);
}

.main-nav .nav-group > a:hover,
.main-nav .nav-group .link-btn:hover,
.main-nav .nav-group .categories-menu summary:hover {
	transform: translateY(-1px);
	filter: brightness(1.08);
}

.main-nav .nav-group > a.is-active,
.main-nav .nav-group .categories-menu summary.is-active {
	background: #ffffff;
	color: #11409e;
	border-color: #ffffff;
	box-shadow: 0 10px 20px rgba(6, 24, 66, 0.26);
}

.cart-link {
	background: rgba(9, 44, 116, 0.82);
}

.cart-pill {
	background: #ffffff;
	color: #1a55cb;
}

.nav-toggle {
	display: none !important;
}

.filter-panel {
	position: sticky;
	top: 10px;
	z-index: 24;
	padding: 14px;
	background: rgba(255, 255, 255, 0.97);
	border: 1px solid #cfdefa;
	box-shadow: 0 10px 24px rgba(16, 43, 92, 0.1);
}

.catalog-filters {
	grid-template-columns: minmax(250px, 1.2fr) 1px minmax(220px, 0.85fr) auto;
}

.filters-block label {
	color: #264a95;
}

.search-inline {
	grid-template-columns: 1fr auto;
}

.search-inline .btn {
	height: 40px;
}

.filters-divider {
	background: linear-gradient(180deg, transparent 0%, #c8d9fb 14%, #c8d9fb 86%, transparent 100%);
}

.catalog-head {
	margin-bottom: 10px;
}

.catalog-count {
	background: #edf4ff;
	color: #1b4da9;
	border: 1px solid #cfe0ff;
}

.catalog-hero {
	display: none !important;
}

.product-grid {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 8px;
}

.product-card {
	border-color: #d7e4fc;
	background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

.product-card.is-new {
	border-color: #4f7fdd;
	box-shadow: 0 0 0 2px rgba(31, 99, 224, 0.16), 0 16px 30px rgba(17, 44, 90, 0.12);
}

.new-strip {
	padding: 7px 10px;
	border-bottom: 1px solid #1a56c7;
	background: linear-gradient(135deg, #2b6ee7, #1e58c0);
	color: #ffffff;
	text-align: center;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.product-card.is-new .offer-badge,
.product-card.is-new .card-cart-mark {
	top: 40px;
}

.product-card:hover {
	border-color: #b6ccf4;
	box-shadow: 0 16px 30px rgba(17, 44, 90, 0.12);
}

.product-card.in-cart {
	border-color: #78a0ed;
	box-shadow: 0 0 0 2px rgba(31, 99, 224, 0.14), 0 16px 30px rgba(17, 44, 90, 0.12);
}

.offer-badge {
	background: linear-gradient(135deg, #e85050, #c93636);
	color: #ffffff;
	border: 1px solid #b32a2a;
}

.stock-ribbon {
	background: rgba(170, 32, 32, 0.9);
	color: #ffffff;
}

.product-image {
	background: #edf4ff;
	border-bottom: 1px solid #d8e4fb;
}

.product-image::after {
	content: 'Mas detalles';
	background: rgba(10, 30, 72, 0.86);
}

.product-body {
	padding: 12px 12px 9px;
	gap: 6px;
}

.product-category {
	color: #2453ae;
}

.product-actions {
	padding: 0 12px 10px;
}

.product-actions form {
	display: block;
}

.qty-inline,
.qty-input {
	display: none !important;
}

.add-cart-btn {
	width: 100%;
	height: 36px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
}

.btn-icon {
	font-size: 0.9rem;
}

.in-cart-badge {
	margin: 0 12px 12px;
	background: #edf4ff;
	border: 1px solid #cfe0ff;
	color: #1f4ea7;
}

.badge-cancel-btn {
	border-color: #95b7f4;
	color: #2454af;
}

input,
select,
textarea {
	border-color: #c9daf8;
	background: #ffffff;
	color: #12213f;
}

input:focus,
select:focus,
textarea:focus {
	border-color: #4f7fdc;
	box-shadow: 0 0 0 3px rgba(31, 99, 224, 0.15);
}

.btn-soft {
	background: #f1f6ff;
	border-color: #c8dafb;
	color: #1b4da9;
}

.site-footer {
	background: linear-gradient(160deg, #081c43 0%, #0f2d66 100%);
	border-top: 1px solid rgba(136, 171, 238, 0.34);
	color: #dce8ff;
}

.footer-block {
	background: rgba(255, 255, 255, 0.05);
	border-color: rgba(141, 176, 240, 0.3);
}

.footer-icon {
	color: #9bbdff;
}

.footer-contact-list li,
.footer-cta p,
.footer-copy {
	color: #dce8ff;
}

.footer-map-wrap {
	background: #0a1e46;
	border-color: rgba(141, 176, 240, 0.32);
}

.footer-whatsapp-btn {
	background: linear-gradient(135deg, #1fbb70, #15945a);
	border-color: #1fbb70;
	color: #ffffff;
}

.footer-whatsapp-btn:hover {
	box-shadow: 0 10px 18px rgba(12, 89, 54, 0.36);
}

@media (max-width: 1040px) {
	.header-logo-link img {
		max-height: 180px;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		min-width: 94px;
		padding: 9px 10px;
		font-size: 0.69rem;
	}
}

@media (max-width: 860px) {
	.main-nav {
		display: grid;
		grid-template-columns: 1fr;
		gap: 8px;
		padding: 8px;
		border-radius: 18px;
		border: 1px solid #7fa5e8;
		background: linear-gradient(180deg, #052364 0%, #0a327a 100%);
		box-shadow: 0 18px 34px rgba(6, 22, 60, 0.28);
	}

	.header-logo-link {
		order: 1;
		border: 0;
		box-shadow: none;
		border-radius: 14px;
		background: transparent;
	}

	.header-logo-link img {
		max-height: 148px;
		border-radius: 12px;
	}

	.nav-group {
		position: static;
		transform: none;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px;
	}

	.nav-left {
		order: 2;
	}

	.nav-right {
		order: 3;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		width: 100%;
		min-width: 0;
		padding: 9px 8px;
		font-size: 0.72rem;
	}

	.filter-panel {
		top: 8px;
	}
}

@media (max-width: 560px) {
	.header-logo-link img {
		max-height: 128px;
	}

	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		font-size: 0.67rem;
		letter-spacing: 0.04em;
	}

	.catalog-filters {
		grid-template-columns: 1fr;
		gap: 9px;
	}

	.filters-divider {
		display: none;
	}

	.filter-actions {
		justify-content: flex-start;
	}

	.search-inline {
		grid-template-columns: 1fr auto;
	}

	.product-grid {
		grid-template-columns: repeat(auto-fill, minmax(158px, 1fr));
		gap: 8px;
	}
}

/* ===== Header Compact + Ticker Admin Edit ===== */
body.has-catalog-tools .site-header {
	margin-bottom: 10px;
	padding: 4px 0 8px;
}

body.has-catalog-tools .header-logo-link {
	border-radius: 18px;
}

body.has-catalog-tools .header-logo-link img {
	max-height: 154px;
}

body.has-catalog-tools .nav-left,
body.has-catalog-tools .nav-right {
	top: 50%;
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
	padding: 8px 11px;
	font-size: 0.68rem;
	min-width: 88px;
}

.header-tools {
	margin-top: 8px;
	padding: 10px 12px;
	border-radius: 14px;
	position: static;
	top: auto;
	z-index: auto;
	background:
		radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.18), transparent 44%),
		linear-gradient(180deg, var(--cf-950), var(--cf-900));
	border: 1px solid var(--cf-800);
	box-shadow: 0 12px 26px rgba(9, 32, 77, 0.22);
}

.header-catalog-filters {
	display: grid;
	grid-template-columns: minmax(280px, 1.25fr) 1px minmax(210px, 0.85fr) auto;
	gap: 10px;
	align-items: end;
}

.header-tools .filters-block label {
	font-size: 0.75rem;
	margin-bottom: 2px;
	color: rgba(255, 255, 255, 0.88);
}

.header-tools input {
	height: 36px;
	padding-top: 7px;
	padding-bottom: 7px;
	background: var(--cf-50);
	border: 1px solid var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.75),
		0 8px 16px rgba(29, 40, 78, 0.06);
}

.header-tools input::placeholder {
	color: rgba(29, 40, 78, 0.62);
}

.header-tools input:focus {
	outline: none;
	background: var(--cf-100);
	border-color: var(--cf-300);
	box-shadow: 0 0 0 3px rgba(98, 157, 234, 0.25);
}

.header-tools select {
	height: 36px;
	padding-top: 7px;
	padding-bottom: 7px;
	background: var(--cf-50);
	border: 1px solid var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.75),
		0 8px 16px rgba(29, 40, 78, 0.06);
}

.header-tools select:focus {
	outline: none;
	background: var(--cf-100);
	border-color: var(--cf-300);
	box-shadow: 0 0 0 3px rgba(98, 157, 234, 0.25);
}

.catalog-search-sticky input {
	background: var(--cf-50);
	border: 1px solid var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
}

.catalog-search-sticky input::placeholder {
	color: rgba(29, 40, 78, 0.62);
}

.catalog-search-sticky input:focus {
	outline: none;
	background: var(--cf-100);
	border-color: var(--cf-300);
	box-shadow: 0 0 0 3px rgba(98, 157, 234, 0.25);
}

.catalog-search-sticky select {
	background: var(--cf-50);
	border: 1px solid var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
}

.catalog-search-sticky select:focus {
	outline: none;
	background: var(--cf-100);
	border-color: var(--cf-300);
	box-shadow: 0 0 0 3px rgba(98, 157, 234, 0.25);
}

/* iOS/Safari: asegura color correcto en inputs claros */
.header-tools input,
.catalog-search-sticky input {
	-webkit-text-fill-color: var(--cf-950);
}

.header-tools .search-inline {
	grid-template-columns: 1fr auto;
	gap: 8px;
}

.header-tools .search-inline .btn {
	height: 36px;
	padding-inline: 14px;
	font-size: 0.78rem;
}

.header-tools .catalog-count {
	margin: 0;
	font-size: 0.82rem;
	padding: 7px 10px;
	white-space: nowrap;
}

.announcement-ticker {
	margin-top: 6px;
	padding: 8px 12px;
	border-radius: 12px;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 8px;
	align-items: center;
	background: linear-gradient(135deg, #0a347a, #1349a6);
	border: 1px solid #2d62bf;
	box-shadow: 0 8px 18px rgba(9, 34, 79, 0.26);
}

.announcement-track {
	position: relative;
	min-height: 22px;
	display: flex;
	align-items: center;
}

.announcement-item {
	display: none;
	align-items: center;
	gap: 8px;
	text-decoration: none;
	color: #f3f8ff;
	font-size: 0.88rem;
	font-weight: 700;
	line-height: 1.2;
}

.announcement-item.is-active {
	display: inline-flex;
}

.announcement-index {
	color: #8db7ff;
	font-weight: 800;
}

.announcement-text {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.announcement-toggle {
	height: 30px;
	padding: 0 10px;
	border-radius: 999px;
	border: 1px solid rgba(169, 198, 255, 0.65);
	background: rgba(255, 255, 255, 0.13);
	color: #eaf2ff;
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	cursor: pointer;
}

.announcement-toggle:hover {
	background: rgba(255, 255, 255, 0.2);
}

.admin-announcements-header {
	margin-top: 20px;
}

.admin-announcements-card {
	padding: 14px;
}

.admin-announcements-form {
	display: grid;
	gap: 10px;
}

.admin-announcement-row {
	display: grid;
	grid-template-columns: 120px minmax(260px, 1fr) minmax(260px, 1fr) 84px;
	gap: 10px;
	align-items: end;
	padding: 10px;
	border: 1px solid #d7e4fc;
	border-radius: 12px;
	background: #f8fbff;
}

.admin-announcement-title {
	font-weight: 800;
	font-size: 0.9rem;
	color: #234a99;
}

.admin-announcement-fields {
	display: grid;
	gap: 4px;
}

.admin-announcement-fields label {
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #2a4d94;
}

.admin-announcement-check {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.82rem;
	font-weight: 700;
	color: #244b9e;
	padding-bottom: 8px;
}

.admin-announcement-actions {
	display: flex;
	justify-content: flex-end;
}

@media (max-width: 1080px) {
	body.has-catalog-tools .header-logo-link img {
		max-height: 132px;
	}

	.header-catalog-filters {
		grid-template-columns: 1fr 1fr auto;
	}

	.header-catalog-filters .filters-divider {
		display: none;
	}

	.header-catalog-filters .search-block {
		grid-column: 1 / -1;
	}

	.admin-announcement-row {
		grid-template-columns: 100px 1fr 1fr;
	}

	.admin-announcement-check {
		grid-column: 1 / -1;
		padding-bottom: 0;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .header-banner-row {
		padding: 0 6px;
	}

	body.has-catalog-tools .main-nav {
		padding: 6px;
		border-radius: 14px;
		gap: 6px;
	}

	body.has-catalog-tools .header-logo-link img {
		max-height: 108px;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		font-size: 0.66rem;
		min-height: 34px;
		padding: 8px 8px;
	}

	.header-tools {
		margin-top: 6px;
		padding: 9px;
	}

	.header-catalog-filters {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.header-catalog-filters .search-inline {
		grid-template-columns: 1fr auto;
	}

	.header-catalog-filters .filter-actions {
		justify-content: flex-start;
	}

	.announcement-ticker {
		padding: 8px 10px;
		grid-template-columns: 1fr;
	}

	.announcement-toggle {
		justify-self: start;
	}

	.announcement-item {
		font-size: 0.82rem;
	}

	.admin-announcement-row {
		grid-template-columns: 1fr;
	}

	.admin-announcement-title {
		font-size: 0.86rem;
	}

	.admin-announcement-actions {
		justify-content: stretch;
	}

	.admin-announcement-actions .btn {
		width: 100%;
	}
}

/* ===== Premium Header Pass v2 ===== */
body.has-catalog-tools .site-header {
	padding: 3px 0 6px;
	margin-bottom: 8px;
	background: linear-gradient(180deg, #041c4a 0%, #0a2e72 100%);
}

body.has-catalog-tools .header-banner-row {
	width: min(1240px, 98vw);
	margin: 0 auto;
	padding: 7px;
	border-radius: 20px;
	border: 1px solid rgba(143, 176, 241, 0.42);
	background: linear-gradient(155deg, rgba(7, 35, 88, 0.94), rgba(12, 52, 121, 0.92));
	box-shadow: 0 16px 30px rgba(5, 23, 62, 0.33);
}

body.has-catalog-tools .main-nav {
	position: relative;
	display: block;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
}

body.has-catalog-tools .header-logo-link {
	display: block;
	width: 100%;
	height: clamp(86px, 10.2vw, 134px);
	padding: 0;
	border-radius: 14px;
	border: 1px solid rgba(164, 194, 246, 0.45);
	background: linear-gradient(180deg, #061f52, #0a2d70);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

body.has-catalog-tools .header-logo-link img {
	width: 100%;
	height: 100%;
	max-height: none;
	object-fit: contain;
	object-position: center;
}

body.has-catalog-tools .nav-group {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	display: flex;
	gap: 8px;
}

body.has-catalog-tools .nav-left {
	left: 10px;
}

body.has-catalog-tools .nav-right {
	right: 10px;
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
	min-width: 86px;
	padding: 7px 10px;
	font-size: 0.64rem;
	letter-spacing: 0.06em;
	border: 1px solid rgba(167, 198, 250, 0.84);
	background: rgba(6, 36, 98, 0.76);
	backdrop-filter: blur(2px);
	color: #f5f9ff;
	box-shadow: 0 8px 14px rgba(6, 24, 62, 0.28);
}

body.has-catalog-tools .main-nav .nav-group > a.is-active,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary.is-active {
	background: #ffffff;
	color: #133f9e;
	border-color: #ffffff;
}

body.has-catalog-tools .cart-link {
	background: rgba(7, 42, 112, 0.8);
}

body.has-catalog-tools .cart-pill {
	min-width: 18px;
	height: 18px;
	font-size: 0.66rem;
}

body.has-catalog-tools .header-tools {
	margin-top: 7px;
	padding: 9px 10px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid #cddffc;
	box-shadow: 0 8px 18px rgba(9, 32, 77, 0.14);
}

body.has-catalog-tools .header-catalog-filters {
	grid-template-columns: minmax(240px, 1.2fr) 1px minmax(220px, 0.8fr) auto;
	gap: 8px;
}

body.has-catalog-tools .header-tools .filters-block label {
	font-size: 0.7rem;
	letter-spacing: 0.04em;
}

body.has-catalog-tools .header-tools input,
body.has-catalog-tools .header-tools select {
	height: 34px;
}

body.has-catalog-tools .header-tools .search-inline .btn {
	height: 34px;
	font-size: 0.74rem;
}

body.has-catalog-tools .header-tools .catalog-count {
	font-size: 0.78rem;
	padding: 6px 9px;
}

body.has-catalog-tools .announcement-ticker {
	margin-top: 5px;
	padding: 6px 10px;
	border-radius: 10px;
	grid-template-columns: 1fr auto;
	gap: 6px;
	background: linear-gradient(135deg, #0a387f, #1651b6);
	border-color: #386fcb;
	box-shadow: 0 7px 15px rgba(8, 31, 76, 0.24);
}

body.has-catalog-tools .announcement-track {
	min-height: 20px;
	position: relative;
}

body.has-catalog-tools .announcement-item {
	position: absolute;
	inset: 0;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	opacity: 0;
	transform: translateY(4px);
	pointer-events: none;
	transition: opacity 0.24s ease, transform 0.24s ease;
	font-size: 0.82rem;
}

body.has-catalog-tools .announcement-item.is-active {
	position: relative;
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

body.has-catalog-tools .announcement-toggle {
	height: 26px;
	padding: 0 9px;
	font-size: 0.67rem;
}

body.has-catalog-tools .site-content {
	padding-top: 2px;
}

@media (max-width: 980px) {
	body.has-catalog-tools .header-logo-link {
		height: clamp(82px, 12vw, 116px);
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		min-width: 78px;
		padding: 6px 8px;
		font-size: 0.6rem;
	}

	body.has-catalog-tools .header-catalog-filters {
		grid-template-columns: 1fr 1fr auto;
	}

	body.has-catalog-tools .header-catalog-filters .filters-divider {
		display: none;
	}

	body.has-catalog-tools .header-catalog-filters .search-block {
		grid-column: 1 / -1;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1240px, 99vw);
		padding: 6px;
		border-radius: 14px;
	}

	body.has-catalog-tools .main-nav {
		display: grid;
		grid-template-columns: 1fr;
		gap: 6px;
	}

	body.has-catalog-tools .header-logo-link {
		order: 1;
		height: clamp(84px, 26vw, 116px);
	}

	body.has-catalog-tools .nav-group {
		position: static;
		transform: none;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 6px;
	}

	body.has-catalog-tools .nav-left {
		order: 2;
	}

	body.has-catalog-tools .nav-right {
		order: 3;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		width: 100%;
		min-width: 0;
		min-height: 32px;
		font-size: 0.64rem;
		border-radius: 10px;
	}

	body.has-catalog-tools .header-tools {
		padding: 8px;
	}

	body.has-catalog-tools .header-catalog-filters {
		grid-template-columns: 1fr;
		gap: 7px;
	}

	body.has-catalog-tools .header-catalog-filters .search-inline {
		grid-template-columns: 1fr auto;
	}

	body.has-catalog-tools .header-catalog-filters .filter-actions {
		justify-content: flex-start;
	}

	body.has-catalog-tools .announcement-ticker {
		grid-template-columns: 1fr auto;
		padding: 6px 8px;
	}

	body.has-catalog-tools .announcement-item {
		font-size: 0.76rem;
	}
}

@media (max-width: 560px) {
	body.has-catalog-tools .header-logo-link {
		height: clamp(78px, 24vw, 98px);
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		font-size: 0.58rem;
	}

	body.has-catalog-tools .header-tools .search-inline {
		grid-template-columns: 1fr auto;
	}

	body.has-catalog-tools .header-tools .search-inline .btn {
		padding-inline: 12px;
	}

	body.has-catalog-tools .announcement-ticker {
		grid-template-columns: 1fr;
	}

	body.has-catalog-tools .announcement-toggle {
		justify-self: start;
	}
}

/* ===== Commercial Intense v3 ===== */
body {
	background:
		radial-gradient(circle at 8% -8%, rgba(78, 146, 255, 0.24) 0%, transparent 34%),
		radial-gradient(circle at 92% 4%, rgba(37, 101, 227, 0.2) 0%, transparent 36%),
		linear-gradient(180deg, #e9f1ff 0%, #f8fbff 42%, #eef5ff 100%);
}

body.has-catalog-tools .site-header {
	background: linear-gradient(180deg, #03163c 0%, #07307a 65%, #0a45a7 100%);
}

body.has-catalog-tools .header-banner-row {
	background:
		radial-gradient(circle at 15% 10%, rgba(255, 255, 255, 0.13) 0, transparent 26%),
		radial-gradient(circle at 86% 80%, rgba(255, 161, 61, 0.25) 0, transparent 30%),
		linear-gradient(155deg, rgba(6, 36, 94, 0.96), rgba(13, 61, 148, 0.96));
	border-color: rgba(156, 193, 255, 0.52);
	box-shadow:
		0 20px 36px rgba(5, 21, 57, 0.34),
		inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

body.has-catalog-tools .header-logo-link {
	border-color: rgba(170, 206, 255, 0.6);
	background:
		radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.15) 0, transparent 44%),
		linear-gradient(180deg, #08266a, #0b3d9a);
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
	border-color: rgba(188, 216, 255, 0.95);
	background: linear-gradient(135deg, rgba(8, 43, 118, 0.92), rgba(18, 76, 176, 0.88));
	color: #f8fbff;
}

body.has-catalog-tools .main-nav .nav-group > a:hover,
body.has-catalog-tools .main-nav .nav-group .link-btn:hover,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary:hover {
	filter: brightness(1.08) saturate(1.08);
	transform: translateY(-1px);
}

body.has-catalog-tools .main-nav .nav-group > a.is-active {
	background: linear-gradient(135deg, #ffffff, #dce9ff);
	color: #0d3f9d;
	border-color: #ffffff;
}

body.has-catalog-tools .repair-link {
	background: linear-gradient(135deg, #ff8a2a, #ff5a1e) !important;
	border-color: #ffc18d !important;
	color: #ffffff !important;
	text-shadow: 0 1px 0 rgba(73, 24, 0, 0.4);
	box-shadow: 0 8px 16px rgba(149, 56, 0, 0.35);
}

body.has-catalog-tools .repair-link:hover {
	filter: brightness(1.07) saturate(1.08);
}

body.has-catalog-tools .header-tools {
	background:
		radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.18), transparent 44%),
		linear-gradient(180deg, var(--cf-950), var(--cf-900));
	border-color: var(--cf-800);
	box-shadow:
		0 10px 24px rgba(9, 35, 83, 0.16),
		inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

body.has-catalog-tools .header-tools .filters-block label {
	color: rgba(255, 255, 255, 0.88);
}

body.has-catalog-tools .header-tools input,
body.has-catalog-tools .header-tools select {
	border-color: var(--cf-200);
}

body.has-catalog-tools .header-tools input {
	background: var(--cf-50);
	border-color: var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
	-webkit-text-fill-color: var(--cf-950);
}

body.has-catalog-tools .header-tools select {
	background: var(--cf-50);
	border-color: var(--cf-200);
	color: var(--cf-950);
	caret-color: var(--cf-950);
	-webkit-text-fill-color: var(--cf-950);
}

body.has-catalog-tools .header-tools select option {
	background: var(--cf-950);
	color: #ffffff;
}

body.has-catalog-tools .header-tools input::placeholder {
	color: rgba(29, 40, 78, 0.62);
}

body.has-catalog-tools .header-tools .search-inline .btn {
	background: linear-gradient(135deg, #1b62df, #1a49ad);
	border-color: #1a4dad;
}

body.has-catalog-tools .announcement-ticker {
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(circle at 12% 30%, rgba(255, 255, 255, 0.18), transparent 30%),
		linear-gradient(120deg, #0046be 0%, #0b61de 52%, #126de8 100%);
	border-color: #6da9ff;
}

body.has-catalog-tools .announcement-ticker::before {
	content: '';
	position: absolute;
	top: 0;
	left: -32%;
	width: 32%;
	height: 100%;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0));
	animation: tickerSweep 5.2s linear infinite;
	pointer-events: none;
}

@keyframes tickerSweep {
	0% {
		left: -32%;
	}
	100% {
		left: 132%;
	}
}

body.has-catalog-tools .announcement-track {
	justify-content: center;
}

body.has-catalog-tools .announcement-item {
	width: 100%;
	justify-content: center;
	text-align: center;
	font-size: 0.9rem;
	font-weight: 800;
	letter-spacing: 0.01em;
}

.announcement-index {
	display: none !important;
}

body.has-catalog-tools .announcement-text {
	text-decoration: none;
}

body.has-catalog-tools .announcement-toggle {
	border-color: rgba(202, 223, 255, 0.8);
	background: rgba(255, 255, 255, 0.16);
}

.product-grid {
	gap: 10px;
}

.product-card {
	background:
		linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
	border-color: #c7dafb;
	box-shadow: 0 10px 22px rgba(17, 46, 97, 0.1);
}

.product-card:hover {
	transform: translateY(-5px);
	border-color: #88b0f2;
	box-shadow: 0 20px 34px rgba(13, 44, 95, 0.18);
}

.product-card .price {
	color: #0e367f;
}

.add-cart-btn {
	background: linear-gradient(135deg, #1666eb, #1149ad);
	border-color: #1148aa;
	box-shadow: 0 8px 16px rgba(12, 44, 99, 0.22);
}

.add-cart-btn:hover {
	filter: brightness(1.06);
}

.card-surface {
	border-color: #cddffc;
}

.empty-state {
	background: linear-gradient(180deg, #ffffff, #f3f8ff);
}

@media (max-width: 860px) {
	body.has-catalog-tools .announcement-item {
		font-size: 0.8rem;
	}

	body.has-catalog-tools .announcement-ticker::before {
		animation-duration: 6.4s;
	}
}

@media (max-width: 560px) {
	body.has-catalog-tools .header-banner-row {
		padding: 5px;
	}

	body.has-catalog-tools .header-tools {
		padding: 7px;
	}

	body.has-catalog-tools .announcement-item {
		font-size: 0.75rem;
	}
}

/* ===== Commercial Intensa B | Neon Tech ===== */
html,
body,
button,
input,
select,
textarea,
a,
h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
label {
	font-family: 'Nunito Sans', 'Trebuchet MS', sans-serif;
}

body {
	background:
		radial-gradient(circle at 12% -10%, rgba(31, 196, 255, 0.16) 0%, transparent 34%),
		radial-gradient(circle at 88% 2%, rgba(0, 111, 255, 0.18) 0%, transparent 36%),
		linear-gradient(180deg, #edf4ff 0%, #f7fbff 48%, #eef6ff 100%);
}

body.has-catalog-tools .header-banner-row {
	width: min(1120px, 92vw);
	padding: 8px;
	border-radius: 16px;
	background:
		radial-gradient(circle at 14% 10%, rgba(20, 255, 255, 0.16) 0, transparent 30%),
		linear-gradient(145deg, #061f56 0%, #08337f 62%, #0d4cb5 100%);
	border: 1px solid rgba(118, 209, 255, 0.55);
	box-shadow:
		0 18px 34px rgba(5, 22, 61, 0.34),
		0 0 0 1px rgba(112, 206, 255, 0.2) inset;
}

body.has-catalog-tools .header-logo-link {
	height: clamp(88px, 10vw, 126px);
	border: 1px solid rgba(138, 216, 255, 0.6);
	box-shadow:
		inset 0 0 0 1px rgba(196, 238, 255, 0.26),
		0 0 24px rgba(54, 184, 255, 0.2);
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
body.has-catalog-tools .repair-link,
body.has-catalog-tools .cart-link,
.btn:not(.icon-btn),
.footer-whatsapp-btn,
.announcement-toggle {
	min-height: 38px;
	min-width: 128px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-transform: uppercase;
	text-align: center;
	font-weight: 800;
	letter-spacing: 0.05em;
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
body.has-catalog-tools .cart-link {
	border-color: rgba(150, 225, 255, 0.95);
	background: linear-gradient(135deg, rgba(8, 56, 142, 0.9), rgba(9, 108, 196, 0.86));
	box-shadow:
		0 8px 16px rgba(6, 27, 72, 0.34),
		0 0 10px rgba(81, 203, 255, 0.2);
}

body.has-catalog-tools .repair-link {
	background: linear-gradient(135deg, #00a6ff, #00d4ff) !important;
	border-color: #9ff3ff !important;
	color: #032242 !important;
	text-shadow: none;
	box-shadow:
		0 8px 16px rgba(2, 66, 100, 0.32),
		0 0 12px rgba(123, 240, 255, 0.4);
}

body.has-catalog-tools .header-tools {
	border-color: #a8dbff;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 249, 255, 0.98));
	box-shadow:
		0 12px 22px rgba(8, 34, 80, 0.18),
		0 0 0 1px rgba(169, 232, 255, 0.3) inset;
}

body.has-catalog-tools .header-tools .search-inline .btn {
	min-width: 118px;
	background: linear-gradient(135deg, #0f73ee, #08b7ff);
	border-color: #0fa4ff;
}

body.has-catalog-tools .announcement-ticker {
	padding: 8px 10px;
	border-radius: 11px;
	background:
		linear-gradient(120deg, #004bd3 0%, #008cff 44%, #00cfff 100%);
	border-color: rgba(155, 236, 255, 0.9);
	box-shadow:
		0 10px 20px rgba(6, 32, 84, 0.26),
		0 0 16px rgba(63, 205, 255, 0.36);
}

body.has-catalog-tools .announcement-track {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
}

body.has-catalog-tools .announcement-item {
	width: 100%;
	justify-content: center;
	text-align: center;
	font-size: 0.92rem;
	font-weight: 900;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

body.has-catalog-tools .announcement-text {
	width: 100%;
	display: block;
	font-weight: 900;
	text-transform: uppercase;
	text-align: center;
}

.announcement-index {
	display: none !important;
}

.btn:not(.icon-btn) {
	text-transform: uppercase;
}

@media (max-width: 860px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1120px, 95vw);
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .repair-link,
	body.has-catalog-tools .cart-link {
		min-width: 0;
		width: 100%;
	}
}

/* ===== Admin Usability v2 ===== */
.admin-products-grid-card {
	padding: 10px;
}

.admin-products-table-wrap {
	width: 100%;
	overflow-x: auto;
}

.admin-products-table {
	min-width: 1040px;
	table-layout: auto;
}

.admin-products-table .col-id {
	width: 56px;
}

.admin-products-table .col-thumb {
	width: 72px;
}

.admin-products-table .col-name {
	width: 44ch;
}

.admin-products-table .col-category {
	width: 20ch;
}

.admin-products-table .col-price,
.admin-products-table .col-offer {
	width: 11ch;
}

.admin-products-table .col-active {
	width: 9ch;
}

.admin-products-table .col-actions {
	width: 220px;
}

.admin-announcement-toolbar {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 10px;
	flex-wrap: wrap;
}

.admin-rotation-field {
	min-width: 220px;
}

.admin-announcement-list {
	display: grid;
	gap: 10px;
}

.admin-announcement-row {
	display: grid;
	grid-template-columns: 100px minmax(260px, 1fr) minmax(260px, 1fr) 88px 84px;
	gap: 10px;
	align-items: end;
}

.admin-announcement-remove {
	height: 34px;
}

@media (max-width: 860px) {
	.admin-products-table {
		min-width: 0;
		border-collapse: separate;
		border-spacing: 0 10px;
	}

	.admin-products-table colgroup,
	.admin-products-table thead {
		display: none;
	}

	.admin-products-table tbody {
		display: grid;
		gap: 10px;
	}

	.admin-products-table tr[data-admin-product-row] {
		display: grid;
		gap: 8px;
		padding: 10px;
		border: 1px solid #c7dafb;
		border-radius: 12px;
		background: #f8fbff;
	}

	.admin-products-table tr[data-admin-no-results-row] {
		display: block;
		padding: 10px;
		border-radius: 10px;
		border: 1px dashed #c6d9fc;
		background: #f7faff;
	}

	.admin-products-table tr[data-admin-no-results-row] td {
		display: block;
		border: 0;
		padding: 0;
	}

	.admin-products-table td {
		display: grid;
		grid-template-columns: 96px 1fr;
		gap: 8px;
		border: 0;
		padding: 0;
		overflow: visible;
		align-items: center;
	}

	.admin-products-table td.cell-thumb {
		align-items: center;
	}

	.admin-products-table td.cell-thumb .admin-product-thumb {
		margin: 0;
	}

	.admin-products-table td::before {
		content: attr(data-label);
		font-size: 0.72rem;
		font-weight: 800;
		text-transform: uppercase;
		letter-spacing: 0.04em;
		color: #2453ae;
	}

	.cell-id {
		text-align: left;
	}

	.admin-products-table .cell-name .admin-inline-field {
		min-width: 0;
	}

	.admin-actions-cell {
		display: flex !important;
		gap: 6px;
		flex-wrap: wrap;
	}

	.admin-actions-cell::before {
		display: none;
	}

	.quick-edit-state {
		width: 100%;
		justify-content: center;
	}

	.admin-announcement-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.admin-announcement-row {
		grid-template-columns: 1fr;
	}

	.admin-announcement-remove {
		width: 100%;
	}
}

/* ===== Layout Tune: mobile + desktop header clarity ===== */
body.has-catalog-tools .header-banner-row {
	width: min(1080px, 94vw);
	margin: 0 auto;
}

body.has-catalog-tools .main-nav .nav-group > a,
body.has-catalog-tools .main-nav .nav-group .link-btn,
body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
body.has-catalog-tools .repair-link,
body.has-catalog-tools .cart-link {
	white-space: nowrap;
}

@media (min-width: 861px) {
	body.has-catalog-tools .main-nav {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(360px, 620px) minmax(0, 1fr);
		gap: 10px;
		align-items: center;
	}

	body.has-catalog-tools .nav-group {
		position: static;
		transform: none;
	}

	body.has-catalog-tools .nav-left {
		display: flex;
		justify-content: flex-end;
		flex-wrap: wrap;
		gap: 8px;
	}

	body.has-catalog-tools .nav-right {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		gap: 8px;
	}

	body.has-catalog-tools .header-logo-link {
		height: clamp(90px, 9vw, 122px);
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .repair-link,
	body.has-catalog-tools .cart-link {
		min-width: 0;
		padding: 8px 10px;
		font-size: 0.62rem;
		min-height: 34px;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1080px, 96vw);
	}

	body.has-catalog-tools .main-nav {
		display: grid;
		grid-template-columns: 1fr;
		gap: 6px;
	}

	body.has-catalog-tools .header-logo-link {
		order: 1;
		height: clamp(82px, 23vw, 104px);
	}

	body.has-catalog-tools .nav-group {
		position: static;
		transform: none;
	}

	body.has-catalog-tools .nav-left {
		order: 2;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 6px;
	}

	body.has-catalog-tools .nav-right {
		order: 3;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 6px;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .repair-link,
	body.has-catalog-tools .cart-link {
		width: 100%;
		min-width: 0;
		min-height: 30px;
		padding: 6px 6px;
		font-size: 0.54rem;
		letter-spacing: 0.04em;
		line-height: 1;
	}
}

/* ===== Product Card Price Tuning ===== */
.product-card .price-group {
	align-items: center;
}

.product-card .price {
	text-align: center;
	font-size: 1.1em;
}

/* ===== Cart + WhatsApp UX ===== */
.cart-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 14px 16px;
	background: linear-gradient(135deg, #eef4ff, #f7fbff);
	border: 1px solid #d6e4ff;
}

.cart-head-main h1 {
	margin-bottom: 4px;
}

.cart-head-main p {
	margin: 0;
	color: #4b5f84;
}

.cart-head-meta {
	display: grid;
	justify-items: end;
	gap: 6px;
}

.cart-head-actions {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

.cart-head-actions form {
	margin: 0;
}

.cart-head-actions .btn {
	min-height: 34px;
	padding-inline: 14px;
	font-weight: 800;
	text-transform: uppercase;
}

.cart-head-total {
	margin: 0;
	font-weight: 900;
	letter-spacing: 0.03em;
	color: #123269;
}

.summary-actions {
	margin-top: 10px;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 8px;
}

.btn-whatsapp {
	background: linear-gradient(135deg, #21bf63, #159456);
	color: #fff;
	border-color: #0f7f48;
}

.btn-whatsapp:hover {
	box-shadow: 0 10px 18px rgba(13, 86, 54, 0.35);
}

.wa-icon-svg {
	display: inline-block;
	vertical-align: middle;
}

.footer-icon-whatsapp {
	align-items: center;
}

.footer-icon-whatsapp .wa-icon-svg {
	width: 16px;
	height: 16px;
}

.footer-whatsapp-btn .wa-icon-svg {
	width: 18px;
	height: 18px;
}

@media (max-width: 760px) {
	.cart-head {
		flex-direction: column;
		align-items: flex-start;
	}

	.cart-head-meta {
		width: 100%;
		justify-items: start;
	}

	.cart-head-actions {
		width: 100%;
		justify-content: flex-start;
	}

	.summary-actions {
		grid-template-columns: 1fr;
	}
}

/* ===== Announcement Arrows ===== */
body.has-catalog-tools .announcement-ticker {
	display: grid;
	grid-template-columns: 36px minmax(0, 1fr) 36px;
	align-items: center;
	gap: 6px;
}

body.has-catalog-tools .announcement-track {
	min-height: 34px;
}

.announcement-nav-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 10px;
	border: 1px solid #7ea3ef;
	background: #ffffff;
	color: #244b9e;
	font-size: 1.15rem;
	font-weight: 900;
	line-height: 1;
	cursor: pointer;
	transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.announcement-nav-btn:hover {
	background: #edf4ff;
	box-shadow: 0 8px 14px rgba(27, 70, 150, 0.18);
}

.announcement-nav-btn:disabled {
	opacity: 0.35;
	cursor: not-allowed;
	box-shadow: none;
}

@media (max-width: 760px) {
	body.has-catalog-tools .announcement-ticker {
		grid-template-columns: 30px minmax(0, 1fr) 30px;
		gap: 4px;
	}

	.announcement-nav-btn {
		width: 28px;
		height: 28px;
		border-radius: 8px;
		font-size: 1rem;
	}
}

/* ===== Mobile Header Simplification ===== */
@media (max-width: 860px) {
	body.has-catalog-tools .header-banner-row {
		display: flex !important;
		flex-direction: column !important;
		gap: 8px !important;
	}

	/* Orden en movil: logo/menu, barra mensajes, filtros */
	body.has-catalog-tools .main-nav {
		order: 1;
		display: block !important;
	}

	body.has-catalog-tools .announcement-ticker {
		order: 2;
	}

	body.has-catalog-tools .header-tools {
		order: 3;
		position: static !important;
		top: auto;
		z-index: auto;
	}

	/* Compactar menu en un unico boton */
	body.has-catalog-tools .main-nav .nav-group {
		display: none !important;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 6px;
		margin-top: 8px;
	}

	body.has-catalog-tools .main-nav.is-open .nav-left,
	body.has-catalog-tools .main-nav.is-open .nav-right {
		position: static !important;
		transform: none !important;
	}

	body.has-catalog-tools .nav-toggle {
		display: inline-flex !important;
		position: static !important;
		width: 100%;
		min-height: 38px;
		padding: 8px 10px;
		border-radius: 10px;
		font-size: 0.68rem;
		font-weight: 900;
		letter-spacing: 0.08em;
		text-transform: uppercase;
	}

	body.has-catalog-tools .nav-toggle span {
		display: none !important;
	}

	body.has-catalog-tools .header-tools .search-submit-btn {
		min-width: 40px !important;
		width: 40px;
		padding: 0 !important;
	}

	body.has-catalog-tools .header-tools .search-submit-btn .search-btn-label {
		display: none;
	}

	body.has-catalog-tools .header-tools .search-submit-btn .search-btn-icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	body.has-catalog-tools .header-tools .search-inline {
		grid-template-columns: minmax(0, 1fr) 40px !important;
	}
}

.search-submit-btn .search-btn-icon {
	display: none;
}

/* ===== Catalog Tools Placement ===== */
.catalog-search-sticky {
	display: none;
}

body.has-catalog-tools .announcement-ticker.container {
	margin-top: 10px;
	margin-bottom: 8px;
}

body.has-catalog-tools .header-tools.container {
	margin-bottom: 10px;
}

@media (max-width: 860px) {
	.catalog-search-sticky {
		display: block;
		position: sticky;
		top: 8px;
		z-index: 95;
		padding: 8px;
		margin-top: 8px;
		margin-bottom: 6px;
		background:
			radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.16), transparent 44%),
			linear-gradient(180deg, var(--cf-950), var(--cf-900));
		border: 1px solid var(--cf-800);
		border-radius: 14px;
	}

	.catalog-search-sticky .search-inline {
		grid-template-columns: minmax(0, 1fr) 40px !important;
	}

	.catalog-search-sticky .search-submit-btn {
		min-width: 40px !important;
		width: 40px;
		padding: 0 !important;
	}

	.catalog-search-sticky .search-submit-btn .search-btn-label {
		display: none;
	}

	.catalog-search-sticky .search-submit-btn .search-btn-icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	body.has-catalog-tools .announcement-ticker.container {
		margin-top: 0;
		margin-bottom: 6px;
	}

	body.has-catalog-tools .header-tools.container {
		position: static !important;
		top: auto !important;
		z-index: auto !important;
		margin-bottom: 8px;
	}

	body.has-catalog-tools .header-tools .search-block,
	body.has-catalog-tools .header-tools .filters-divider {
		display: none !important;
	}
}

/* ===== Mobile Menu + Product List ===== */
@media (max-width: 860px) {
	body.has-catalog-tools .main-nav {
		display: flex !important;
		flex-direction: column;
		align-items: stretch;
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		order: 1;
		align-self: center;
	}

	body.has-catalog-tools .main-nav .nav-toggle {
		order: 2;
		margin-top: 6px;
		font-size: 0.92rem !important;
		font-weight: 900 !important;
		letter-spacing: 0.06em !important;
		text-transform: uppercase;
		color: #f8fbff;
		line-height: 1.1;
	}

	body.has-catalog-tools .main-nav .nav-group {
		order: 3;
	}

	#catalogGrid.product-grid {
		display: flex !important;
		flex-direction: column !important;
		grid-template-columns: 1fr !important;
		gap: 4px !important;
	}

	#catalogGrid .product-card {
		width: 100% !important;
		max-width: none !important;
		min-width: 0 !important;
		display: grid;
		grid-template-columns: 1fr;
		grid-template-areas:
			"media"
			"content"
			"actions"
			"badge badge";
		gap: 7px;
		border: 1px solid #bcd6ff;
		border-radius: 15px;
		box-shadow: 0 10px 24px rgba(13, 44, 95, 0.12), 0 0 0 1px rgba(89, 140, 230, 0.14) inset;
		background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
		padding: 9px;
		overflow: hidden;
	}

	#catalogGrid .product-card:last-child {
		border-bottom: 1px solid #c9daf7;
	}

	#catalogGrid .product-card:hover {
		transform: none;
		box-shadow: none;
	}

	#catalogGrid .product-image {
		grid-area: media;
		aspect-ratio: 4 / 3;
		border-radius: 12px;
		border: 1px solid #d3e3ff;
		background: #fff;
		box-shadow: 0 3px 10px rgba(25, 62, 121, 0.08);
	}

	#catalogGrid .product-image img {
		padding: 4px;
	}

	#catalogGrid .product-body {
		grid-area: content;
		padding: 0;
		gap: 4px;
	}

	#catalogGrid .product-body h3 {
		min-height: auto;
		font-size: 0.99rem;
		line-height: 1.28;
		-webkit-line-clamp: 2;
	}

	#catalogGrid .product-category {
		font-size: 0.72rem;
		letter-spacing: 0.04em;
	}

	#catalogGrid .price:not(.price-original) {
		margin-top: 1px;
		font-size: 1.58rem;
		font-weight: 900;
		text-align: left;
		display: inline-flex;
		align-items: center;
		padding: 4px 11px;
		border-radius: 999px;
		background: linear-gradient(135deg, #e8f1ff, #d4e6ff);
		border: 1px solid #a8c9ff;
		color: #0d3e91;
		width: fit-content;
		letter-spacing: 0.015em;
	}

	#catalogGrid .price-original {
		background: transparent;
		border: 0;
		padding: 0;
	}

	#catalogGrid .product-actions {
		grid-area: actions;
		padding: 0;
		align-self: stretch;
	}

	#catalogGrid .product-actions form {
		grid-template-columns: 1fr;
		justify-items: end;
	}

	#catalogGrid .add-cart-btn {
		width: auto;
		min-width: 122px;
		max-width: 148px;
		justify-self: end;
		height: 34px;
		padding-inline: 12px;
		font-size: 0.81rem;
		gap: 5px;
		border-radius: 10px;
	}

	#catalogGrid .in-cart-badge {
		grid-area: badge;
		margin: 2px 0 0;
		padding: 6px 9px;
		min-height: 26px;
		width: 100%;
	}

	#catalogGrid .card-cart-mark {
		display: none;
	}

	#catalogGrid .offer-badge,
	#catalogGrid .new-strip,
	#catalogGrid .stock-ribbon {
		position: static;
		display: inline-flex;
		margin: 0 4px 4px 0;
	}

	#catalogGrid .product-description-excerpt {
		display: none !important;
		margin: 6px 0 0;
		font-size: 0.84rem;
		line-height: 1.42;
		color: #4f607f;
	}
}

@media (max-width: 460px) {
	#catalogGrid .product-card {
		padding: 8px;
		gap: 6px;
	}

	#catalogGrid .product-image {
		aspect-ratio: 1 / 1;
	}

	#catalogGrid .product-body h3 {
		font-size: 0.95rem;
	}

	#catalogGrid .price:not(.price-original) {
		font-size: 1.5rem;
	}

	#catalogGrid .add-cart-btn {
		min-width: 116px;
		max-width: 140px;
		height: 33px;
		font-size: 0.8rem;
	}
}

/* ===== Mobile Cleanup Final (Unified) ===== */
@media (max-width: 860px) {
	body.has-catalog-tools {
		/* Escala movil unificada (lectura + touch) */
		--m-fs-xs: 0.74rem;
		--m-fs-sm: 0.82rem;
		--m-fs-md: 0.92rem;
		--m-fs-lg: 0.98rem;
		--m-fs-price: 1.42rem;
		--m-lh-tight: 1.22;
		--m-lh-normal: 1.32;
		--m-touch: 42px;
		--m-gap-1: 6px;
		--m-gap-2: 8px;
	}

	body.has-catalog-tools .header-banner {
		padding: 8px 0 6px;
	}

	body.has-catalog-tools .header-banner-row {
		display: grid !important;
		grid-template-columns: 1fr;
		gap: 8px !important;
	}

	body.has-catalog-tools .main-nav {
		display: grid !important;
		grid-template-columns: 1fr;
		gap: var(--m-gap-1);
		padding: 7px;
		border-radius: 14px;
		background: linear-gradient(145deg, #0f3f93 0%, #1f5fcc 52%, #2e74ea 100%);
		box-shadow: 0 12px 22px rgba(8, 33, 84, 0.28);
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		order: 1;
		display: block;
		width: 100%;
		max-width: 100%;
		margin: 0;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		display: block;
		width: 100%;
		height: clamp(78px, 21vw, 108px);
		max-height: none;
		object-fit: cover;
		border-radius: 10px;
	}

	body.has-catalog-tools .main-nav .nav-toggle {
		order: 2;
		width: 100%;
		min-height: var(--m-touch);
		margin: 0;
		border-radius: 10px;
		border: 1px solid rgba(255, 255, 255, 0.42);
		background: rgba(8, 21, 63, 0.34);
		color: #ffffff;
		font-size: var(--m-fs-sm) !important;
		font-weight: 800 !important;
		letter-spacing: 0.035em !important;
		text-align: center;
		line-height: var(--m-lh-tight);
	}

	body.has-catalog-tools .main-nav .nav-group {
		order: 3;
		display: none !important;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 5px;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		min-height: var(--m-touch);
		padding: 8px 9px;
		border-radius: 9px;
		font-size: var(--m-fs-xs);
		font-weight: 800;
		letter-spacing: 0.03em;
		text-align: center;
		justify-content: center;
		line-height: var(--m-lh-tight);
	}

	body.has-catalog-tools .announcement-ticker.container {
		margin-top: 0;
		margin-bottom: 6px;
		padding: 6px;
	}

	body.has-catalog-tools .announcement-track {
		min-height: 34px;
	}

	body.has-catalog-tools .announcement-item {
		text-align: center;
		justify-content: center;
	}

	body.has-catalog-tools .announcement-text {
		width: 100%;
		text-align: center;
		font-size: var(--m-fs-sm);
		font-weight: 800;
		letter-spacing: 0.02em;
		line-height: var(--m-lh-tight);
	}

	.catalog-search-sticky {
		display: block;
		position: sticky;
		top: 8px;
		z-index: 96;
		margin-top: 0;
		margin-bottom: 6px;
		padding: 7px;
		border-radius: 12px;
	}

	.catalog-search-sticky .search-inline {
		grid-template-columns: minmax(0, 1fr) 38px !important;
		gap: var(--m-gap-1);
	}

	.catalog-search-sticky input[type="text"] {
		min-height: var(--m-touch);
		padding: 9px 11px;
		font-size: var(--m-fs-md);
		line-height: var(--m-lh-tight);
	}

	.catalog-search-sticky .search-submit-btn {
		width: var(--m-touch);
		min-width: var(--m-touch) !important;
		height: var(--m-touch);
		padding: 0 !important;
		border-radius: 9px;
	}

	.catalog-search-sticky .search-submit-btn .search-btn-label {
		display: none !important;
	}

	.catalog-search-sticky .search-submit-btn .search-btn-icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	body.has-catalog-tools .header-tools.container {
		position: static !important;
		top: auto !important;
		z-index: auto !important;
		margin-bottom: 8px;
		padding: 7px;
	}

	body.has-catalog-tools .header-tools .search-block,
	body.has-catalog-tools .header-tools .filters-divider {
		display: none !important;
	}

	body.has-catalog-tools .header-tools .catalog-filters {
		display: grid;
		grid-template-columns: 1fr;
		gap: var(--m-gap-1);
	}

	body.has-catalog-tools .header-tools .category-block label {
		font-size: var(--m-fs-xs);
		letter-spacing: 0.04em;
	}

	body.has-catalog-tools .header-tools .category-block select {
		min-height: var(--m-touch);
		font-size: var(--m-fs-md);
	}

	body.has-catalog-tools .header-tools .filter-actions {
		display: grid;
		grid-template-columns: 1fr auto;
		align-items: center;
		gap: var(--m-gap-1);
	}

	body.has-catalog-tools .header-tools .catalog-count,
	body.has-catalog-tools .header-tools .btn.btn-soft {
		font-size: var(--m-fs-sm);
	}

	#catalogGrid.product-grid {
		display: flex !important;
		flex-direction: column !important;
		gap: 6px !important;
	}

	#catalogGrid .product-card {
		position: relative;
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch;
		padding: 8px;
		border: 1px solid #b7d2ff;
		border-radius: 15px;
		box-shadow: 0 10px 22px rgba(16, 52, 114, 0.13), 0 0 0 1px rgba(128, 169, 236, 0.16) inset;
		background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
		gap: var(--m-gap-1);
		overflow: hidden;
	}

	#catalogGrid .product-image,
	#catalogGrid .product-body,
	#catalogGrid .product-actions,
	#catalogGrid .in-cart-badge {
		grid-area: auto !important;
	}

	#catalogGrid .product-image {
		aspect-ratio: 4 / 3;
		border-radius: 12px;
		border: 1px solid #cfe0ff;
		box-shadow: 0 4px 10px rgba(28, 66, 130, 0.09);
	}

	#catalogGrid .product-image img {
		padding: 4px;
	}

	#catalogGrid .product-body {
		display: flex;
		flex-direction: column;
		gap: 4px;
		padding: 0;
	}

	#catalogGrid .product-body h3 {
		font-size: var(--m-fs-lg);
		line-height: var(--m-lh-normal);
		min-height: 0;
	}

	#catalogGrid .product-body h3 a {
		color: #0f1f44;
	}

	#catalogGrid .product-category {
		font-size: var(--m-fs-xs);
		margin: 0;
	}

	#catalogGrid .price:not(.price-original) {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		font-size: var(--m-fs-price);
		font-weight: 900;
		padding: 5px 10px;
		line-height: 1.15;
		margin-top: 2px;
		border-radius: 11px;
		background: linear-gradient(135deg, #e6f0ff, #d6e6ff);
		border: 1px solid #a9c7f8;
		color: #0f3f93;
		box-shadow: 0 4px 10px rgba(25, 75, 156, 0.14);
	}

	#catalogGrid .price-group {
		display: grid;
		gap: 3px;
	}

	#catalogGrid .product-actions form {
		display: grid;
		grid-template-columns: 1fr;
		justify-items: stretch;
		gap: 0;
	}

	#catalogGrid .add-cart-btn {
		width: 100%;
		min-width: 0;
		max-width: none;
		justify-self: stretch;
		height: var(--m-touch);
		padding-inline: 12px;
		font-size: var(--m-fs-sm);
		font-weight: 800;
		letter-spacing: 0.03em;
		border-radius: 10px;
		line-height: var(--m-lh-tight);
	}

	#catalogGrid .new-strip,
	#catalogGrid .offer-badge {
		position: static !important;
		display: inline-flex;
		align-items: center;
		align-self: flex-start;
		margin: 0 0 2px 0 !important;
	}

	#catalogGrid .stock-ribbon {
		position: static !important;
		display: block;
		width: 100%;
		margin: 0 0 2px 0 !important;
		padding: 6px 8px;
		border-radius: 8px;
		font-size: var(--m-fs-xs);
		letter-spacing: 0.04em;
	}

	#catalogGrid .in-cart-badge {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 7px;
		padding: 5px 8px;
		margin: 0;
		font-size: var(--m-fs-xs);
	}
}

@media (max-width: 520px) {
	body.has-catalog-tools .main-nav .header-logo-link img {
		height: clamp(72px, 20vw, 96px);
		max-height: none;
		object-fit: cover;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary {
		font-size: 0.71rem;
	}

	body.has-catalog-tools .announcement-text {
		font-size: 0.78rem;
	}

	#catalogGrid .product-card {
		padding: 7px;
		gap: 5px;
	}

	#catalogGrid .product-image {
		aspect-ratio: 1 / 1;
	}

	#catalogGrid .price:not(.price-original) {
		font-size: 1.34rem;
		padding: 4px 9px;
	}

	#catalogGrid .product-body h3 {
		font-size: 0.93rem;
		line-height: 1.24;
	}

	#catalogGrid .add-cart-btn {
		height: 40px;
		font-size: 0.8rem;
	}
}

/* ===== Admin Visual Unification ===== */
.admin-top-nav {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 8px;
	margin-bottom: 12px;
	padding: 8px;
	border-radius: 12px;
	background: linear-gradient(180deg, #f9fbff 0%, #f0f5ff 100%);
	border: 1px solid #d6e1f7;
}

.btn-admin-nav {
	min-height: 38px;
	padding: 9px 10px;
	background: #eaf2ff;
	color: #1f4d9d;
	border: 1px solid #c9daff;
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.btn-admin-nav.is-active {
	background: linear-gradient(135deg, #1c64e2, #0b47bf);
	color: #fff;
	border-color: #0b47bf;
	box-shadow: 0 8px 16px rgba(24, 71, 160, 0.25);
}

.admin-header-actions {
	display: inline-flex;
	gap: 8px;
	flex-wrap: wrap;
}

.admin-shortcuts-card h2,
.admin-categories-create h2,
.admin-categories-list-card h2 {
	margin: 0 0 10px;
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: 1.05rem;
}

.admin-shortcuts-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

.admin-categories-create,
.admin-categories-list-card,
.admin-shortcuts-card {
	padding: 12px;
}

.admin-contact-card {
	padding: 12px;
	max-width: 720px;
}

.admin-contact-form {
	display: grid;
	gap: 10px;
}

.admin-contact-help,
.admin-contact-preview {
	margin: 0;
	font-size: 0.84rem;
	color: #2a4f9b;
}

.admin-contact-preview strong {
	font-family: 'Montserrat', 'Arial Black', sans-serif;
	font-size: 1.02rem;
	color: #123a87;
}

.admin-contact-actions {
	display: flex;
}

.admin-category-create-form {
	display: grid;
	gap: 10px;
}

.admin-category-groups-card h2 {
	margin: 0 0 8px;
}

.admin-category-group-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 10px;
}

.admin-category-group-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px solid #c8dcff;
	background: #edf4ff;
	color: #214893;
}

.admin-category-group-tag strong {
	font-size: 0.78rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

.admin-category-group-tag small {
	font-size: 0.71rem;
	color: #4c69a6;
}

.admin-category-group-create-form {
	display: grid;
	gap: 8px;
}

.admin-category-group-create-grid {
	display: grid;
	grid-template-columns: minmax(220px, 1.2fr) minmax(200px, 1fr) auto;
	gap: 10px;
	align-items: end;
}

.admin-category-create-grid {
	display: grid;
	grid-template-columns: minmax(220px, 1.2fr) minmax(180px, 0.9fr) minmax(220px, 1fr);
	gap: 10px;
}

.admin-categories-list {
	display: grid;
	gap: 10px;
}

.admin-categories-hint {
	margin: 0 0 10px;
	font-size: 0.84rem;
	color: #2c4f97;
}

.admin-categories-feedback {
	margin: 0 0 10px;
	padding: 9px 11px;
	border-radius: 10px;
	border: 1px solid #d4e1f8;
	background: #eef4ff;
	font-size: 0.84rem;
	font-weight: 700;
	color: #264a95;
}

.admin-categories-feedback.is-success {
	background: #e8f7ef;
	border-color: #bde6ce;
	color: #176844;
}

.admin-categories-feedback.is-error {
	background: #fdecec;
	border-color: #f2c2c2;
	color: #972a2a;
}

.admin-categories-empty {
	margin: 0;
	padding: 12px;
	border: 1px dashed #c8d9f8;
	border-radius: 12px;
	background: #f8fbff;
	color: #3e5d9f;
	font-weight: 700;
}

.admin-category-row {
	display: grid;
	grid-template-columns: 40px 58px minmax(220px, 1.2fr) minmax(180px, 0.9fr) minmax(170px, 0.8fr) auto;
	gap: 8px;
	align-items: end;
	padding: 10px;
	border-radius: 10px;
	border: 1px solid #d4e0f8;
	background: #f9fbff;
}

.admin-category-row label {
	font-size: 0.75rem;
	font-weight: 800;
	color: #37559b;
}

.admin-category-id {
	align-self: center;
	font-weight: 900;
	font-size: 0.9rem;
	color: #2d4c92;
}

.admin-category-meta {
	display: grid;
	gap: 6px;
	align-self: stretch;
	align-content: start;
}

.admin-category-count {
	display: inline-flex;
	padding: 4px 8px;
	border-radius: 999px;
	background: #edf4ff;
	border: 1px solid #d1e2ff;
	color: #2a4f9b;
	font-size: 0.76rem;
	font-weight: 800;
}

.admin-category-state {
	width: fit-content;
}

.admin-category-actions {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.admin-category-group-field select {
	min-width: 170px;
}

.admin-category-merge-block {
	grid-column: 1 / -1;
	display: grid;
	gap: 6px;
	padding-top: 6px;
	border-top: 1px dashed #c7d8f7;
}

.admin-category-merge-block label {
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #37559b;
}

.admin-category-merge-grid {
	display: grid;
	grid-template-columns: minmax(220px, 1fr) auto;
	gap: 8px;
	align-items: center;
}

.admin-category-merge-note {
	margin: 0;
	font-size: 0.76rem;
	color: #4b6397;
}

.admin-category-row.is-dirty {
	background: #fffdf6;
}

.admin-category-row.is-saving {
	opacity: 0.75;
}

.admin-products-table .admin-inline-field,
.admin-category-row input,
.admin-category-row select,
.admin-announcements-form input,
.admin-announcements-form select,
.admin-announcements-form textarea {
	font-size: 0.88rem;
}

.admin-announcements-card,
.admin-products-grid-card,
.admin-product-form,
.admin-categories-create,
.admin-categories-list-card {
	background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
	border: 1px solid #d6e1f8;
}

.admin-actions-cell .btn,
.admin-actions-cell .icon-btn {
	border-color: #caddff;
	background: #edf4ff;
	color: #264f9e;
}

.admin-actions-cell .btn.btn-primary {
	background: linear-gradient(135deg, #1c64e2, #0b47bf);
	color: #fff;
	border-color: #0b47bf;
}

.admin-actions-cell .btn.btn-danger {
	background: linear-gradient(135deg, #d45252, #b83434);
	color: #fff;
	border-color: #9e2a2a;
}

@media (max-width: 960px) {
	.admin-top-nav {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.admin-shortcuts-grid {
		grid-template-columns: 1fr;
	}

	.admin-category-create-grid {
		grid-template-columns: 1fr;
	}

	.admin-category-group-create-grid {
		grid-template-columns: 1fr;
	}

	.admin-category-row {
		grid-template-columns: 1fr;
		align-items: stretch;
	}

	.admin-category-id,
	.admin-category-meta,
	.admin-category-actions {
		align-self: start;
	}

	.admin-category-merge-grid {
		grid-template-columns: 1fr;
	}

	.admin-category-actions .icon-btn {
		width: 36px;
		height: 36px;
	}

	.admin-contact-actions .btn {
		width: 100%;
	}
}

@media (max-width: 860px) {
	.admin-top-nav .btn-admin-nav {
		min-height: 40px;
		font-size: 0.78rem;
	}

	.admin-products-grid-card {
		padding: 8px;
	}

	.admin-products-table tr[data-admin-product-row] {
		padding: 9px;
		border-radius: 11px;
	}

	.admin-products-table td {
		grid-template-columns: 92px 1fr;
		gap: 6px;
	}

	.admin-products-table td::before {
		font-size: 0.7rem;
	}

	.admin-actions-cell .icon-btn {
		width: 34px;
		height: 34px;
	}
}

/* ===== Cart Badge Green (desktop + mobile) ===== */
.in-cart-badge,
#catalogGrid .in-cart-badge {
	color: #1d6b43 !important;
	background: #e8f8ee !important;
	border: 1px solid #bfe8cf !important;
}

.in-cart-badge strong,
#catalogGrid .in-cart-badge strong {
	color: #0f5d35;
}

.badge-cancel-btn {
	border-color: #8dc9a7 !important;
	color: #1d6b43 !important;
	background: #ffffff !important;
}

.badge-cancel-btn:hover {
	background: #ecf9f1 !important;
}

/* ===== Mobile: cart icon button in sticky search bar ===== */
.search-cart-mobile {
	display: none;
}

/* Product card action integrated inside product-body (mobile only) */
@media (max-width: 860px) {
	#catalogGrid .product-body .product-actions,
	.product-grid .product-body .product-actions {
		padding: 0;
		margin-top: auto;
	}

	#catalogGrid .product-body .product-actions form,
	.product-grid .product-body .product-actions form {
		display: flex;
		justify-content: flex-end;
		gap: 0;
		grid-template-columns: none;
	}

	#catalogGrid .product-body .add-cart-btn,
	.product-grid .product-body .add-cart-btn {
		width: auto;
		min-width: 122px;
	}
}

/* Desktop restore: keep legacy product card presentation */
@media (min-width: 861px) {
	#catalogGrid .product-body .product-meta-grid,
	.product-grid .product-body .product-meta-grid {
		display: grid;
		grid-template-columns: 1fr;
		gap: 6px;
		margin-top: auto;
		align-items: stretch;
	}

	#catalogGrid .product-body .product-meta-grid .price-original-spacer,
	.product-grid .product-body .product-meta-grid .price-original-spacer {
		display: none;
	}

	#catalogGrid .product-body .product-meta-grid .price,
	.product-grid .product-body .product-meta-grid .price {
		margin: 0;
	}

	#catalogGrid .product-body .product-meta-grid .product-actions,
	.product-grid .product-body .product-meta-grid .product-actions {
		padding: 0;
		margin: 2px 0 0;
	}

	#catalogGrid .product-body .product-meta-grid .product-actions form,
	.product-grid .product-body .product-meta-grid .product-actions form {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0;
	}

	#catalogGrid .product-body .product-meta-grid .add-cart-btn,
	.product-grid .product-body .product-meta-grid .add-cart-btn {
		width: 100%;
		min-width: 0;
		max-width: none;
	}

	#catalogGrid .product-body .product-meta-grid .in-cart-badge,
	.product-grid .product-body .product-meta-grid .in-cart-badge {
		margin: 0;
		width: 100%;
	}
}

@media (max-width: 860px) {
	.catalog-search-sticky .search-inline.has-mobile-cart {
		grid-template-columns: minmax(0, 1fr) 38px 38px !important;
		gap: 5px;
	}

	.catalog-search-sticky .search-cart-mobile {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 38px;
		min-width: 38px;
		height: 36px;
		padding: 0;
		border-radius: 9px;
		border: 1px solid #177d45;
		background: linear-gradient(135deg, #26a45b, #178446);
		color: #ffffff;
		position: relative;
	}

	.catalog-search-sticky .search-cart-mobile .btn-icon {
		font-size: 0.95rem;
		line-height: 1;
	}

	.catalog-search-sticky .search-cart-mobile-count {
		position: absolute;
		top: -5px;
		right: -5px;
		min-width: 15px;
		height: 15px;
		padding: 0 4px;
		border-radius: 999px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		background: #effff4;
		color: #0f6738;
		font-size: 0.64rem;
		font-weight: 900;
		line-height: 1;
		border: 1px solid #b9ebcc;
	}
}

/* ===== Header Homogeneous Fix ===== */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1260px, 96vw) !important;
		margin: 0 auto !important;
		padding: 0 !important;
	}

	body.has-catalog-tools .main-nav {
		position: relative !important;
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(420px, 640px) minmax(0, 1fr) !important;
		align-items: center !important;
		gap: 10px !important;
		padding: 10px 14px !important;
		border-radius: 22px !important;
		border: 1px solid rgba(120, 157, 228, 0.55) !important;
		background: linear-gradient(180deg, #0d3e9b 0%, #0a337f 100%) !important;
		box-shadow: 0 18px 32px rgba(7, 24, 63, 0.28) !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .main-nav::before,
	body.has-catalog-tools .main-nav::after {
		display: none !important;
		content: none !important;
	}

	body.has-catalog-tools .header-logo-link {
		position: relative !important;
		display: block !important;
		padding: 0 !important;
		margin: 0 auto !important;
		border: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		border-radius: 14px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .header-logo-link img {
		width: 100% !important;
		max-height: 162px !important;
		height: auto !important;
		object-fit: contain !important;
		border: 0 !important;
		outline: 0 !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools .nav-group {
		position: static !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 8px !important;
	}

	body.has-catalog-tools .nav-left {
		justify-content: flex-end !important;
	}

	body.has-catalog-tools .nav-right {
		justify-content: flex-start !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .repair-link,
	body.has-catalog-tools .cart-link {
		min-width: 104px !important;
		min-height: 36px !important;
		padding: 9px 12px !important;
		border: 0 !important;
		border-radius: 999px !important;
		background: rgba(4, 28, 78, 0.62) !important;
		color: #f4f9ff !important;
		box-shadow: none !important;
		backdrop-filter: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #0f439e !important;
	}
}

/* ===== Tablet Stabilization (prevents intermediate layout break) ===== */
@media (min-width: 861px) and (max-width: 1180px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1140px, 96vw) !important;
		margin: 0 auto !important;
		padding: 8px !important;
	}

	body.has-catalog-tools .main-nav {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(360px, 520px) minmax(0, 1fr) !important;
		align-items: center !important;
		gap: 8px !important;
		padding: 8px 10px !important;
		border-radius: 16px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .header-logo-link {
		height: clamp(92px, 11vw, 128px) !important;
		border-radius: 12px !important;
	}

	body.has-catalog-tools .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		max-height: none !important;
		object-fit: cover !important;
	}

	body.has-catalog-tools .nav-group {
		position: static !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: wrap !important;
		gap: 6px !important;
	}

	body.has-catalog-tools .nav-left {
		justify-content: flex-end !important;
	}

	body.has-catalog-tools .nav-right {
		justify-content: flex-start !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .repair-link,
	body.has-catalog-tools .cart-link {
		min-width: 86px !important;
		min-height: 34px !important;
		padding: 7px 10px !important;
		font-size: 0.62rem !important;
		letter-spacing: 0.04em !important;
	}

	body.has-catalog-tools .announcement-ticker.container {
		margin-top: 6px !important;
		margin-bottom: 6px !important;
	}

	body.has-catalog-tools .header-tools {
		margin-top: 6px !important;
		padding: 9px 10px !important;
	}

	body.has-catalog-tools .header-catalog-filters,
	body.has-catalog-tools .catalog-filters {
		grid-template-columns: 1fr 1fr auto !important;
		gap: 8px !important;
	}

	body.has-catalog-tools .header-catalog-filters .search-block,
	body.has-catalog-tools .catalog-filters .search-block {
		grid-column: 1 / -1 !important;
	}

	body.has-catalog-tools .header-catalog-filters .filters-divider,
	body.has-catalog-tools .catalog-filters .filters-divider {
		display: none !important;
	}

	.product-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 10px !important;
	}

	.footer-legacy-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 10px !important;
	}

	.footer-legacy-grid .footer-block:nth-child(2) {
		grid-column: 1 / -1 !important;
	}
}

/* ===== Desktop Product Card Flow Fix (only desktop/tablet) ===== */
@media (min-width: 861px) {
	#catalogGrid .product-card,
	.product-grid .product-card {
		position: relative;
	}

	#catalogGrid .product-body,
	.product-grid .product-body {
		gap: 5px;
		padding: 12px 12px 10px;
	}

	#catalogGrid .product-body h3,
	.product-grid .product-body h3 {
		min-height: 2.5em;
	}

	/* Keep prices + add button compact and in order */
	#catalogGrid .product-body .product-meta-grid,
	.product-grid .product-body .product-meta-grid {
		display: flex;
		flex-direction: column;
		gap: 4px;
		margin-top: 2px;
	}

	#catalogGrid .product-body .product-meta-grid .price,
	.product-grid .product-body .product-meta-grid .price {
		margin: 0;
	}

	#catalogGrid .product-body .product-meta-grid .price.price-original,
	.product-grid .product-body .product-meta-grid .price.price-original {
		position: absolute;
		left: 10px;
		top: 44px;
		z-index: 4;
		margin: 0;
		padding: 2px 8px;
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.92);
		border: 1px solid #d7e4fb;
		font-size: 0.84rem;
		font-weight: 800;
		line-height: 1.15;
	}

	#catalogGrid .product-body .product-meta-grid .price.price-main,
	#catalogGrid .product-body .product-meta-grid .price.price-offer,
	.product-grid .product-body .product-meta-grid .price.price-main,
	.product-grid .product-body .product-meta-grid .price.price-offer {
		order: 2;
	}

	#catalogGrid .product-body .product-meta-grid .product-actions,
	.product-grid .product-body .product-meta-grid .product-actions {
		order: 3;
		margin-top: 2px;
		padding: 0;
	}

	#catalogGrid .product-body .product-meta-grid .product-actions form,
	.product-grid .product-body .product-meta-grid .product-actions form {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0;
	}

	#catalogGrid .product-body .product-meta-grid .add-cart-btn,
	.product-grid .product-body .product-meta-grid .add-cart-btn {
		width: 100%;
		min-width: 0;
		max-width: none;
	}

	#catalogGrid .product-body .product-meta-grid .price-original-spacer,
	.product-grid .product-body .product-meta-grid .price-original-spacer {
		display: none;
	}

	/* Move "En carrito" above image (below new strip) */
	#catalogGrid .product-body .product-meta-grid .in-cart-badge,
	.product-grid .product-body .product-meta-grid .in-cart-badge {
		position: absolute;
		left: 10px;
		right: 10px;
		top: 10px;
		margin: 0;
		width: auto;
		display: none;
		visibility: visible;
		z-index: 4;
		min-height: 34px;
	}

	#catalogGrid .product-card.is-new .product-body .product-meta-grid .in-cart-badge,
	.product-grid .product-card.is-new .product-body .product-meta-grid .in-cart-badge {
		top: 40px;
	}

	#catalogGrid .product-card.is-new .product-body .product-meta-grid .price.price-original,
	.product-grid .product-card.is-new .product-body .product-meta-grid .price.price-original {
		top: 74px;
	}

	#catalogGrid .product-card.in-cart .product-body .product-meta-grid .in-cart-badge,
	.product-grid .product-card.in-cart .product-body .product-meta-grid .in-cart-badge {
		display: inline-flex;
	}

	/* Reserve space only when badge is visible */
	#catalogGrid .product-card.in-cart .product-image,
	.product-grid .product-card.in-cart .product-image {
		margin-top: 44px;
	}

	/* Keep offer/cart marks anchored to top of image after reserved space */
	#catalogGrid .product-card.in-cart .offer-badge,
	#catalogGrid .product-card.in-cart .card-cart-mark,
	.product-grid .product-card.in-cart .offer-badge,
	.product-grid .product-card.in-cart .card-cart-mark {
		top: 54px;
	}

	#catalogGrid .product-card.in-cart .product-body .product-meta-grid .price.price-original,
	.product-grid .product-card.in-cart .product-body .product-meta-grid .price.price-original {
		top: 88px;
	}

	#catalogGrid .product-card.in-cart.is-new .offer-badge,
	#catalogGrid .product-card.in-cart.is-new .card-cart-mark,
	.product-grid .product-card.in-cart.is-new .offer-badge,
	.product-grid .product-card.in-cart.is-new .card-cart-mark {
		top: 84px;
	}

	#catalogGrid .product-card.in-cart.is-new .product-body .product-meta-grid .price.price-original,
	.product-grid .product-card.in-cart.is-new .product-body .product-meta-grid .price.price-original {
		top: 118px;
	}
}

/* Cart icon quantity bubble on product cards */
.card-cart-mark {
	overflow: visible;
}

.card-cart-mark::after {
	content: attr(data-qty-label);
	position: absolute;
	top: -6px;
	right: -6px;
	min-width: 16px;
	height: 16px;
	padding: 0 4px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
	color: #1a4fab;
	border: 1px solid #9ab7ef;
	font-size: 0.62rem;
	font-weight: 900;
	line-height: 1;
}

.card-cart-mark[data-qty="0"]::after,
.card-cart-mark:not([data-qty])::after {
	display: none;
}

.admin-category-autocomplete {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 32px;
	gap: 6px;
}

.admin-category-autocomplete input {
	width: 100%;
	min-width: 0;
}

.admin-category-reset {
	padding: 0;
	width: 32px;
	min-width: 32px;
	height: 36px;
	font-size: 0.98rem;
	font-weight: 900;
	line-height: 1;
}

.admin-category-native-select {
	display: none !important;
}

.admin-category-results {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	display: grid;
	gap: 4px;
	max-height: 240px;
	overflow-y: auto;
	padding: 6px;
	border-radius: 12px;
	border: 1px solid #bfd4f7;
	background: #ffffff;
	box-shadow: 0 14px 26px rgba(15, 46, 104, 0.16);
	z-index: 70;
}

.admin-category-option {
	width: 100%;
	text-align: left;
	border: 1px solid #d4e2fa;
	background: #f7faff;
	color: #1f4a97;
	border-radius: 9px;
	padding: 8px 10px;
	font-size: 0.87rem;
	font-weight: 700;
	cursor: pointer;
}

.admin-category-option:hover,
.admin-category-option:focus-visible {
	background: #eaf2ff;
	border-color: #9fbbec;
	outline: none;
}

/* Desktop: remove in-card "En carrito" badge and keep compact card flow */
@media (min-width: 861px) {
	#catalogGrid .in-cart-badge,
	.product-grid .in-cart-badge {
		display: none !important;
	}

	#catalogGrid .product-card.in-cart .product-image,
	.product-grid .product-card.in-cart .product-image {
		margin-top: 0 !important;
	}

	#catalogGrid .product-card.in-cart .offer-badge,
	#catalogGrid .product-card.in-cart .card-cart-mark,
	.product-grid .product-card.in-cart .offer-badge,
	.product-grid .product-card.in-cart .card-cart-mark {
		top: 10px !important;
	}

	#catalogGrid .product-card.in-cart.is-new .offer-badge,
	#catalogGrid .product-card.in-cart.is-new .card-cart-mark,
	.product-grid .product-card.in-cart.is-new .offer-badge,
	.product-grid .product-card.in-cart.is-new .card-cart-mark {
		top: 40px !important;
	}

	#catalogGrid .product-card.in-cart .product-body .product-meta-grid .price.price-original,
	.product-grid .product-card.in-cart .product-body .product-meta-grid .price.price-original {
		top: 44px !important;
	}

	#catalogGrid .product-card.in-cart.is-new .product-body .product-meta-grid .price.price-original,
	.product-grid .product-card.in-cart.is-new .product-body .product-meta-grid .price.price-original {
		top: 74px !important;
	}
}

/* Product detail harmony with catalog cards */
.back-catalog-top {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	width: fit-content;
	min-height: 38px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.back-catalog-top .back-tab-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	line-height: 1;
}

.product-view {
	align-items: stretch;
}

.product-media {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	overflow: hidden;
}

.product-media-toolbar {
	display: flex;
	align-self: stretch;
	justify-content: flex-start;
	margin-bottom: 8px;
}

.product-media-toolbar .back-catalog-top {
	min-height: 36px;
	padding: 0 12px;
}

.product-media img {
	display: block;
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: min(100%, 78vh);
	margin: 0 auto;
}

.price-group-detail .price-original {
	font-size: 0.86rem;
}

.product-detail h1 {
	font-size: clamp(1.02rem, 1.55vw, 1.22rem);
	line-height: 1.28;
	font-weight: 800;
}

.product-detail .price.large {
	font-size: 1.16rem;
	margin: 0 0 8px;
}

.product-detail .product-description {
	font-size: 0.95rem;
	line-height: 1.5;
}

.product-detail-actions {
	display: flex;
	align-items: end;
	gap: 10px;
	flex-wrap: wrap;
}

.product-detail .add-cart-form {
	display: grid;
	grid-template-columns: 112px minmax(180px, 1fr);
	gap: 10px;
	align-items: end;
	margin: 0;
	flex: 1;
	min-width: 300px;
}

.product-detail .add-cart-form input[type="number"] {
	height: 40px;
}

.product-detail .add-cart-form .btn {
	height: 40px;
	white-space: nowrap;
}

.product-detail .add-cart-form .detail-add-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.product-detail .add-cart-form .detail-add-icon,
.cart-icon-badge {
	width: 20px;
	height: 20px;
	border-radius: 999px;
	background: #ffffff;
	color: #1a4da9;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 20px;
	box-shadow: inset 0 0 0 1px rgba(148, 177, 235, 0.5);
}

.product-detail .add-cart-form .detail-add-icon .cart-icon-svg,
.cart-icon-badge .cart-icon-svg {
	width: 13px;
	height: 13px;
	display: block;
}

.product-detail-actions .consult-stock-btn {
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	white-space: nowrap;
}

.product-detail-actions .consult-stock-btn .wa-icon-svg {
	width: 16px;
	height: 16px;
}

@media (min-width: 861px) {
	.product-view {
		grid-template-columns: minmax(320px, 1fr) minmax(360px, 1fr);
		gap: 16px;
	}

	.product-media {
		min-height: clamp(340px, 44vw, 760px);
	}

	.product-media img {
		max-height: min(100%, 82vh);
	}

	.product-detail-actions {
		flex-wrap: nowrap;
	}
}

@media (max-width: 980px) {
	.product-media {
		min-height: clamp(260px, 48vw, 420px);
	}

	.product-media img {
		max-height: 62vh;
	}
}

@media (max-width: 560px) {
	.product-media {
		min-height: clamp(220px, 62vw, 340px);
	}

	.product-media img {
		max-height: 56vh;
	}

	.product-detail h1 {
		font-size: 1rem;
	}

	.product-detail-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.back-catalog-top {
		width: 100%;
		justify-content: center;
	}

	.product-media-toolbar {
		margin-bottom: 6px;
	}

	.product-detail .add-cart-form {
		min-width: 0;
		width: 100%;
		grid-template-columns: 96px minmax(0, 1fr);
	}

	.product-detail-actions .consult-stock-btn {
		width: 100%;
	}
}

/* Product detail actions: desktop compact stack */
@media (min-width: 861px) {
	.product-detail-actions {
		display: grid;
		grid-template-columns: minmax(0, 1fr);
		gap: 10px;
		align-items: stretch;
	}

	.product-detail .add-cart-form {
		grid-column: 1;
		min-width: 0;
		width: 100%;
	}

	.product-detail-actions .consult-stock-btn {
		width: 100%;
	}
}

/* Header image recalibration for updated header-sudoku.png */
@media (min-width: 861px) {
	body.has-catalog-tools .main-nav {
		grid-template-columns: minmax(0, 1fr) minmax(300px, 420px) minmax(0, 1fr) !important;
		align-items: center !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(100%, 400px) !important;
		height: clamp(104px, 13.5vw, 176px) !important;
		margin: 0 auto !important;
		padding: 6px 8px !important;
		border-radius: 14px !important;
		background: rgba(8, 33, 90, 0.25) !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		width: auto !important;
		height: 100% !important;
		max-width: 100% !important;
		max-height: 100% !important;
		object-fit: contain !important;
		object-position: center center !important;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .main-nav .header-logo-link {
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		height: clamp(84px, 22vw, 122px) !important;
		padding: 6px 8px !important;
		border-radius: 12px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		width: auto !important;
		height: 100% !important;
		max-width: 100% !important;
		max-height: 100% !important;
		object-fit: contain !important;
		object-position: center center !important;
	}
}

/* Header desktop layout like reference: centered logo + unified button row */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner {
		padding: 8px 0 8px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1200px, 96vw) !important;
		margin: 0 auto !important;
		padding: 0 !important;
	}

	body.has-catalog-tools .main-nav {
		display: grid !important;
		grid-template-columns: 1fr auto 1fr !important;
		grid-template-rows: auto auto !important;
		align-items: center !important;
		column-gap: 10px !important;
		row-gap: 10px !important;
		padding: 0 !important;
		border: 0 !important;
		border-radius: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		overflow: visible !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		grid-row: 1 !important;
		grid-column: 2 !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(340px, 32vw) !important;
		height: clamp(96px, 10vw, 126px) !important;
		margin: 0 auto !important;
		padding: 6px 10px !important;
		border-radius: 18px !important;
		background: rgba(7, 34, 96, 0.46) !important;
		border: 0 !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		width: auto !important;
		height: 100% !important;
		max-width: 100% !important;
		max-height: 100% !important;
		object-fit: contain !important;
		object-position: center center !important;
	}

	body.has-catalog-tools .main-nav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group {
		position: static !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		gap: 10px !important;
	}

	body.has-catalog-tools .main-nav .nav-left {
		grid-row: 2 !important;
		grid-column: 1 / 3 !important;
		justify-self: end !important;
		justify-content: flex-end !important;
	}

	body.has-catalog-tools .main-nav .nav-right {
		grid-row: 2 !important;
		grid-column: 2 / 4 !important;
		justify-self: start !important;
		justify-content: flex-start !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		min-height: 44px !important;
		padding: 0 22px !important;
		border-radius: 999px !important;
		border: 0 !important;
		background: rgba(8, 32, 88, 0.8) !important;
		color: #eef4ff !important;
		font-size: 0.97rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.03em !important;
		text-transform: uppercase !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a:hover,
	body.has-catalog-tools .cart-link:hover,
	body.has-catalog-tools .repair-link:hover {
		filter: brightness(1.08) !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #1e4ea4 !important;
	}

	body.has-catalog-tools .cart-pill {
		margin-left: 8px !important;
		padding: 3px 10px !important;
		border-radius: 999px !important;
		background: #f2f6ff !important;
		color: #1e4ea4 !important;
		border: 0 !important;
		font-weight: 900 !important;
		font-size: 0.84rem !important;
		line-height: 1 !important;
	}
}

/* Desktop header hotfix: compact logo + single clean nav row (no overlap) */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner {
		padding: 4px 0 2px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1120px, 96vw) !important;
		margin: 0 auto !important;
		padding: 0 4px !important;
	}

	body.has-catalog-tools .main-nav {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
		align-items: center !important;
		column-gap: 12px !important;
		row-gap: 6px !important;
		padding: 6px 12px 8px !important;
		border-radius: 18px !important;
		border: 1px solid rgba(126, 172, 247, 0.5) !important;
		background: linear-gradient(180deg, #1d57b6 0%, #174ca8 100%) !important;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
		min-height: 0 !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		order: 1 !important;
		flex: 0 1 100% !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(560px, 48vw) !important;
		height: 82px !important;
		margin: 0 auto !important;
		padding: 2px 4px !important;
		border-radius: 14px !important;
		background: rgba(8, 33, 90, 0.22) !important;
		border: 0 !important;
		box-shadow: none !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		object-fit: contain !important;
		object-position: center center !important;
		transform: none !important;
		transform-origin: center center !important;
	}

	body.has-catalog-tools .main-nav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group {
		order: 2 !important;
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 10px !important;
		width: auto !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools .main-nav .nav-left,
	body.has-catalog-tools .main-nav .nav-right {
		grid-column: auto !important;
		grid-row: auto !important;
		justify-self: auto !important;
		justify-content: center !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		min-width: 136px !important;
		min-height: 44px !important;
		padding: 0 16px !important;
		border-radius: 999px !important;
		border: 0 !important;
		background: rgba(8, 32, 88, 0.88) !important;
		color: #eef4ff !important;
		font-size: 0.95rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.02em !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #1e4ea4 !important;
	}

	body.has-catalog-tools .cart-pill {
		margin-left: 8px !important;
		padding: 3px 10px !important;
		font-size: 0.84rem !important;
		line-height: 1 !important;
		background: #f2f6ff !important;
		color: #1e4ea4 !important;
		border-radius: 999px !important;
	}

	#catalogGrid.product-grid,
	.product-grid {
		gap: 10px !important;
	}
}

@media (min-width: 861px) and (max-width: 1140px) {
	body.has-catalog-tools .main-nav .header-logo-link {
		width: min(500px, 58vw) !important;
		height: 74px !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		transform: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group {
		gap: 8px !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		min-width: 118px !important;
		min-height: 40px !important;
		padding: 0 12px !important;
		font-size: 0.84rem !important;
	}
}

/* ===== Final hotfix 2026-03-29: desktop header + mobile offer badge ===== */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner {
		padding: 6px 0 4px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1240px, 98vw) !important;
		margin: 0 auto !important;
		padding: 0 8px !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) !important;
		grid-template-areas:
			"logo logo logo"
			"left left right" !important;
		column-gap: 14px !important;
		row-gap: 10px !important;
		align-items: center !important;
		padding: 10px 16px 12px !important;
		border-radius: 20px !important;
		border: 1px solid rgba(126, 172, 247, 0.52) !important;
		background: linear-gradient(180deg, #1d57b6 0%, #174ca8 100%) !important;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
		min-height: 0 !important;
	}

	body.has-catalog-tools #mainNav.main-nav::before,
	body.has-catalog-tools #mainNav.main-nav::after {
		display: none !important;
		content: none !important;
	}

	body.has-catalog-tools #mainNav.main-nav > * {
		position: relative !important;
		z-index: 1 !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		grid-area: logo !important;
		justify-self: center !important;
		align-self: center !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(620px, 52vw) !important;
		height: 102px !important;
		margin: 0 !important;
		padding: 4px 8px !important;
		border-radius: 16px !important;
		background: rgba(8, 33, 90, 0.24) !important;
		border: 0 !important;
		overflow: hidden !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		object-fit: contain !important;
		object-position: center center !important;
		transform: none !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		gap: 12px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-left {
		grid-area: left !important;
		justify-content: flex-end !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-right {
		grid-area: right !important;
		justify-content: flex-start !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 8px !important;
		min-width: 134px !important;
		min-height: 44px !important;
		padding: 0 16px !important;
		border-radius: 999px !important;
		border: 0 !important;
		background: rgba(8, 32, 88, 0.88) !important;
		color: #eef4ff !important;
		font-size: 0.93rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.02em !important;
		line-height: 1 !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools #mainNav .nav-right .cart-link {
		min-width: 148px !important;
	}

	body.has-catalog-tools #mainNav .nav-right .repair-link {
		min-width: 176px !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a:hover,
	body.has-catalog-tools #mainNav .nav-group .link-btn:hover,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary:hover {
		filter: brightness(1.07) !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #1e4ea4 !important;
	}

	body.has-catalog-tools #mainNav .cart-link .nav-cart-icon {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 18px !important;
		height: 18px !important;
	}

	body.has-catalog-tools #mainNav .cart-link .cart-icon-svg {
		width: 14px !important;
		height: 14px !important;
		fill: currentColor !important;
	}

	body.has-catalog-tools #mainNav .cart-pill {
		margin-left: 4px !important;
		padding: 3px 10px !important;
		font-size: 0.84rem !important;
		line-height: 1 !important;
		background: #f2f6ff !important;
		color: #1e4ea4 !important;
		border-radius: 999px !important;
	}
}

@media (min-width: 861px) and (max-width: 1160px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1220px, 99vw) !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		padding: 8px 12px 10px !important;
		column-gap: 10px !important;
		row-gap: 8px !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		width: min(540px, 60vw) !important;
		height: 88px !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		gap: 8px !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		min-width: 118px !important;
		min-height: 40px !important;
		padding: 0 12px !important;
		font-size: 0.82rem !important;
	}

	body.has-catalog-tools #mainNav .nav-right .cart-link {
		min-width: 124px !important;
	}

	body.has-catalog-tools #mainNav .nav-right .repair-link {
		min-width: 144px !important;
	}
}

/* Mobile badges: canonical layout (single source of truth) */
@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		position: relative !important;
	}

	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		left: 8px !important;
		right: auto !important;
		bottom: auto !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		height: 24px !important;
		width: auto !important;
		max-width: 112px !important;
		padding: 0 10px !important;
		margin: 0 !important;
		border-radius: 7px !important;
		white-space: nowrap !important;
		line-height: 1 !important;
		transform: none !important;
		z-index: 12 !important;
	}

	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		left: 8px !important;
		right: auto !important;
		bottom: auto !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		height: 24px !important;
		width: auto !important;
		max-width: 112px !important;
		padding: 0 10px !important;
		margin: 0 !important;
		white-space: nowrap !important;
		line-height: 1 !important;
		transform: none !important;
		z-index: 11 !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 36px !important;
	}

	body.page-productos #catalogGrid .product-card .featured-badge,
	body.page-productos .product-grid .product-card .featured-badge {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		right: 8px !important;
		left: auto !important;
		bottom: auto !important;
		z-index: 11 !important;
	}
}

@media (max-width: 420px) {
	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip,
	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		height: 22px !important;
		max-width: 104px !important;
		padding: 0 8px !important;
		font-size: 0.7rem !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 33px !important;
	}
}

@media (max-width: 360px) {
	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip,
	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		top: 7px !important;
		left: 7px !important;
		height: 21px !important;
		max-width: 98px !important;
		padding: 0 7px !important;
		font-size: 0.66rem !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 31px !important;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .main-nav .header-logo-link {
		height: clamp(64px, 18vw, 96px) !important;
		padding: 2px 4px !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		object-fit: contain !important;
		transform: none !important;
	}
}

/* Unified cart icon style across site */
.add-cart-btn .cart-icon-badge {
	margin-left: 6px;
}

.card-cart-mark {
	width: 30px;
	height: 30px;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

.card-cart-mark .cart-icon-badge {
	width: 20px;
	height: 20px;
	flex: 0 0 20px;
}

.search-cart-mobile .cart-icon-badge {
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
}

.search-cart-mobile .cart-icon-badge .cart-icon-svg {
	width: 11px;
	height: 11px;
}

/* Mobile: plain price text (remove oval background) */
@media (max-width: 860px) {
	#catalogGrid .price:not(.price-original),
	#catalogGrid .product-meta-grid .price.price-main,
	#catalogGrid .product-meta-grid .price.price-offer {
		display: inline-block !important;
		width: auto !important;
		padding: 0 !important;
		border: 0 !important;
		border-radius: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
	}
}

/* Mobile cart cards: same visual format as product cards */
@media (max-width: 860px) {
	body.has-catalog-tools .cart-items {
		padding: 8px;
	}

	body.has-catalog-tools .cart-item {
		display: grid !important;
		grid-template-columns: 132px minmax(0, 1fr) !important;
		grid-template-areas:
			"media info"
			"media actions";
		align-items: start;
		gap: 6px 9px;
		padding: 8px;
		border-radius: 13px;
		border: 1px solid #c7dafb;
		background: linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
		box-shadow: 0 4px 10px rgba(20, 56, 118, 0.08);
	}

	body.has-catalog-tools .cart-item + .cart-item {
		margin-top: 8px;
	}

	body.has-catalog-tools .cart-item-media {
		grid-area: media;
		width: 132px;
		height: 132px;
		min-width: 132px;
		border-radius: 10px;
		border: 1px solid #d3e3ff;
		background: #ffffff;
		box-shadow: 0 3px 10px rgba(25, 62, 121, 0.08);
	}

	body.has-catalog-tools .cart-item-media img {
		object-fit: contain;
		padding: 4px;
	}

	body.has-catalog-tools .cart-item-info {
		grid-area: info;
		min-width: 0;
	}

	body.has-catalog-tools .cart-item-info h3 {
		margin: 0 0 4px;
		font-size: 0.98rem;
		line-height: 1.24;
	}

		body.has-catalog-tools .cart-item-info .muted {
			font-size: 0.84rem;
			line-height: 1.25;
		}

		body.has-catalog-tools .cart-item-info .muted strong {
			display: inline-block;
			margin-left: 4px;
			font-size: 1.02rem;
			font-weight: 900;
			color: #0f3f93;
			line-height: 1.08;
		}

		body.has-catalog-tools .cart-item-info .line-total {
			margin-top: 5px;
			font-size: 1.06rem;
			font-weight: 800;
			color: #123d8f;
			line-height: 1.08;
		}

	body.has-catalog-tools .cart-item-actions {
		grid-area: actions;
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		gap: 6px;
		align-items: end;
		justify-items: stretch;
	}

	body.has-catalog-tools .cart-item-actions > form {
		margin: 0;
	}

	body.has-catalog-tools .qty-form {
		display: grid;
		grid-template-columns: 66px minmax(0, 1fr);
		gap: 6px;
		align-items: end;
		width: 100%;
	}

	body.has-catalog-tools .qty-form input {
		width: 100%;
		height: 34px;
		padding: 6px 8px;
		text-align: center;
		border-radius: 8px;
	}

	body.has-catalog-tools .qty-form .btn,
	body.has-catalog-tools .cart-item-actions > form .btn {
		min-height: 34px;
		padding: 0 10px;
		font-size: 0.76rem;
		font-weight: 800;
		letter-spacing: 0.02em;
		text-transform: uppercase;
	}

	body.has-catalog-tools .cart-item-actions > form:last-child .btn {
		height: 34px;
	}
}

@media (max-width: 420px) {
	body.has-catalog-tools .cart-item {
		grid-template-columns: 120px minmax(0, 1fr) !important;
		gap: 5px 8px;
		padding: 7px;
	}

	body.has-catalog-tools .cart-item-media {
		width: 120px;
		height: 120px;
		min-width: 120px;
	}

	body.has-catalog-tools .cart-item-info h3 {
		font-size: 0.94rem;
	}

	body.has-catalog-tools .qty-form {
		grid-template-columns: 60px minmax(0, 1fr);
	}
}

/* Sticky search bar: same icon size + cart shake on add */
@media (max-width: 860px) {
	.catalog-search-sticky .search-submit-btn .search-btn-icon,
	.catalog-search-sticky .search-cart-mobile .cart-icon-badge {
		width: 18px;
		height: 18px;
		flex: 0 0 18px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	.catalog-search-sticky .search-submit-btn .search-btn-icon svg,
	.catalog-search-sticky .search-cart-mobile .cart-icon-badge .cart-icon-svg {
		width: 11px !important;
		height: 11px !important;
	}

	.catalog-search-sticky .search-cart-mobile.is-shaking .cart-icon-badge {
		animation: sticky-cart-shake 560ms cubic-bezier(0.36, 0.07, 0.19, 0.97) 1;
		transform-origin: 50% 52%;
	}
}

@keyframes sticky-cart-shake {
	0% {
		transform: translateX(0) rotate(0deg);
	}
	15% {
		transform: translateX(-1px) rotate(-9deg);
	}
	30% {
		transform: translateX(2px) rotate(8deg);
	}
	45% {
		transform: translateX(-2px) rotate(-7deg);
	}
	60% {
		transform: translateX(2px) rotate(6deg);
	}
	75% {
		transform: translateX(-1px) rotate(-4deg);
	}
	100% {
		transform: translateX(0) rotate(0deg);
	}
}

@media (prefers-reduced-motion: reduce) {
	.catalog-search-sticky .search-cart-mobile.is-shaking .cart-icon-badge {
		animation: none !important;
	}
}

/* Ultra-mobile collision fixes: prevent button overlap in products + cart */
@media (max-width: 560px) {
	body.has-catalog-tools #catalogGrid .product-card {
		grid-template-columns: clamp(104px, 33vw, 126px) minmax(0, 1fr) !important;
		gap: 6px 8px !important;
		padding: 7px !important;
	}

	body.has-catalog-tools #catalogGrid .product-image {
		width: clamp(104px, 33vw, 126px) !important;
		height: clamp(104px, 33vw, 126px) !important;
		max-width: none !important;
	}

	body.has-catalog-tools #catalogGrid .product-body {
		min-height: 0 !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid {
		grid-template-columns: minmax(0, 1fr) !important;
		grid-template-areas:
			"old"
			"main"
			"cart"
			"action" !important;
		gap: 4px !important;
		align-items: stretch !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .price,
	body.has-catalog-tools #catalogGrid .product-meta-grid .price.price-main,
	body.has-catalog-tools #catalogGrid .product-meta-grid .price.price-offer {
		justify-self: start !important;
		display: block !important;
		margin: 0 0 2px 0 !important;
		padding: 0 !important;
		font-size: clamp(1.24rem, 5.2vw, 1.5rem) !important;
		font-weight: 900 !important;
		line-height: 1.05 !important;
		letter-spacing: 0.01em !important;
		color: #0f3f93 !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .price.price-original {
		margin: 0 !important;
		font-size: 0.88rem !important;
		line-height: 1.1 !important;
	}

	body.has-catalog-tools #catalogGrid .price-original-spacer {
		display: none !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .in-cart-badge {
		max-width: none !important;
		width: 100% !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .product-actions {
		width: 100% !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .product-actions form {
		display: grid !important;
		grid-template-columns: 1fr !important;
		justify-items: stretch !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .add-cart-btn {
		width: 100% !important;
		max-width: none !important;
		min-width: 0 !important;
	}

	body.has-catalog-tools .cart-item {
		grid-template-columns: clamp(104px, 33vw, 126px) minmax(0, 1fr) !important;
		gap: 6px 8px !important;
	}

	body.has-catalog-tools .cart-item-media {
		width: clamp(104px, 33vw, 126px) !important;
		height: clamp(104px, 33vw, 126px) !important;
		min-width: 0 !important;
	}

	body.has-catalog-tools .cart-item-actions {
		grid-template-columns: 1fr !important;
		gap: 6px !important;
	}

	body.has-catalog-tools .qty-form {
		grid-template-columns: 62px minmax(0, 1fr) !important;
	}

	body.has-catalog-tools .qty-form .btn,
	body.has-catalog-tools .cart-item-actions > form .btn {
		width: 100% !important;
	}
}

@media (max-width: 380px) {
	body.has-catalog-tools #catalogGrid .product-card {
		grid-template-columns: 1fr !important;
		grid-template-areas:
			"media"
			"content" !important;
	}

	body.has-catalog-tools #catalogGrid .product-image {
		width: 100% !important;
		height: auto !important;
		aspect-ratio: 1 / 1 !important;
	}

	body.has-catalog-tools #catalogGrid .product-meta-grid .price,
	body.has-catalog-tools #catalogGrid .product-meta-grid .price.price-main,
	body.has-catalog-tools #catalogGrid .product-meta-grid .price.price-offer {
		font-size: clamp(1.28rem, 6vw, 1.55rem) !important;
	}

	body.has-catalog-tools .cart-item {
		grid-template-columns: 1fr !important;
		grid-template-areas:
			"media"
			"info"
			"actions" !important;
	}

	body.has-catalog-tools .cart-item-media {
		width: min(100%, 170px) !important;
		height: auto !important;
		aspect-ratio: 1 / 1 !important;
	}

	body.has-catalog-tools .qty-form {
		grid-template-columns: 1fr 1fr !important;
	}
}

/* In-cart badge as cart link (tap/click) */
.in-cart-badge[data-cart-url] {
	cursor: pointer;
}

.in-cart-badge[data-cart-url]:focus-visible {
	outline: 2px solid #7ea3ef;
	outline-offset: 2px;
}

/* Services page */
.services-hero {
	display: block;
	padding: 18px 18px 16px;
	background: linear-gradient(135deg, rgba(20, 55, 135, 0.1), rgba(11, 155, 204, 0.1));
	border: 1px solid rgba(26, 82, 182, 0.22);
}

.services-hero .eyebrow {
	margin: 0 0 8px;
}

.services-hero h1 {
	margin: 0 0 8px;
	font-size: clamp(1.35rem, 2.2vw, 1.95rem);
	color: #10306b;
}

.services-hero p {
	margin: 0;
	color: #264476;
	font-weight: 600;
}

.services-page {
	margin-top: 14px;
	display: grid;
	gap: 14px;
}

.services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
}

.service-card {
	padding: 12px;
	border: 1px solid #c7daf7;
	background: linear-gradient(165deg, #fafdff 0%, #edf5ff 100%);
	display: grid;
	grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
	gap: 14px;
	align-items: stretch;
	position: relative;
	overflow: hidden;
	box-shadow: 0 12px 26px rgba(19, 56, 125, 0.08);
}

.service-card::before {
	content: '';
	position: absolute;
	inset: 0 auto 0 0;
	width: 5px;
	background: linear-gradient(180deg, #2a67d7 0%, #19b7dc 100%);
}

.service-media {
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid #bfd6fa;
	background: #e6f1ff;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.45);
}

.service-card:nth-child(even) .service-media {
	order: 2;
}

.service-media img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.service-body {
	padding: 4px 8px 6px 2px;
	display: grid;
	gap: 8px;
	align-content: start;
}

.service-index {
	margin: 0;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #2a62c0;
}

.service-kicker {
	margin: 0;
	font-size: 0.75rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #0f8ac5;
}

.service-card h3 {
	margin: 0;
	font-size: clamp(1.05rem, 1.9vw, 1.35rem);
	color: #10306b;
	line-height: 1.18;
}

.service-card p {
	margin: 0;
	color: #294874;
	font-size: 0.95rem;
	line-height: 1.45;
}

.service-points {
	margin: 4px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 6px;
}

.service-points li {
	display: grid;
	grid-template-columns: 18px minmax(0, 1fr);
	align-items: start;
	gap: 6px;
	font-size: 0.89rem;
	font-weight: 700;
	color: #1e4386;
}

.service-points li::before {
	content: '✓';
	font-size: 0.86rem;
	font-weight: 900;
	color: #198e5e;
	margin-top: 1px;
}

.services-cta {
	padding: 18px 16px;
	border: 1px solid #bfd5f7;
	background: linear-gradient(135deg, #f7fbff 0%, #e7f1ff 100%);
	box-shadow: 0 12px 24px rgba(16, 55, 122, 0.08);
}

.services-cta h2 {
	margin: 0 0 8px;
	color: #123269;
	font-size: 1.2rem;
}

.services-cta p {
	margin: 0;
	color: #32507f;
	font-weight: 600;
}

.services-cta-actions {
	margin-top: 12px;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.services-cta-actions .btn {
	min-width: 220px;
}

@media (min-width: 861px) {
	body.page-servicios .services-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
		align-items: stretch;
	}

	body.page-servicios .service-card {
		height: 100%;
		grid-template-columns: minmax(200px, 240px) minmax(0, 1fr);
	}

	body.page-servicios .service-media img {
		aspect-ratio: 4 / 3;
	}

	body.page-servicios .header-banner {
		padding: 8px 0 10px !important;
	}

	body.page-servicios .header-banner-row {
		width: min(1220px, 95vw) !important;
		margin: 0 auto !important;
		padding: 0 6px !important;
	}

	body.page-servicios .main-nav {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
		grid-template-areas:
			"logo logo"
			"left right" !important;
		align-items: center !important;
		column-gap: 14px !important;
		row-gap: 10px !important;
		padding: 10px 14px 12px !important;
		border-radius: 20px !important;
		border: 1px solid rgba(126, 172, 247, 0.48) !important;
		background: linear-gradient(180deg, #1d57b6 0%, #174ca8 100%) !important;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
	}

	body.page-servicios .main-nav .header-logo-link {
		grid-area: logo !important;
		order: 0 !important;
		flex: 0 0 auto !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(560px, 56vw) !important;
		height: 88px !important;
		margin: 0 auto !important;
		padding: 4px 10px !important;
		border-radius: 14px !important;
		background: rgba(8, 33, 90, 0.24) !important;
		overflow: hidden !important;
	}

	body.page-servicios .main-nav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		object-fit: contain !important;
	}

	body.page-servicios .main-nav .nav-left {
		grid-area: left !important;
		justify-content: flex-end !important;
	}

	body.page-servicios .main-nav .nav-right {
		grid-area: right !important;
		justify-content: flex-start !important;
	}

	body.page-servicios .main-nav .nav-group {
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: wrap !important;
		align-items: center !important;
		gap: 10px !important;
		width: auto !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.page-servicios .main-nav .nav-group > a,
	body.page-servicios .main-nav .nav-group .link-btn,
	body.page-servicios .main-nav .nav-group .categories-menu summary,
	body.page-servicios .cart-link,
	body.page-servicios .repair-link {
		min-width: 122px !important;
		min-height: 42px !important;
		padding: 0 16px !important;
		font-size: 0.88rem !important;
	}

	body.page-servicios .services-hero,
	body.page-servicios .services-page,
	body.page-servicios .services-cta {
		max-width: 1140px;
		margin-left: auto;
		margin-right: auto;
	}
}

@media (min-width: 861px) and (max-width: 1180px) {
	body.page-servicios .services-grid {
		grid-template-columns: 1fr;
	}

	body.page-servicios .service-card {
		grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
	}

	body.page-servicios .main-nav .nav-group > a,
	body.page-servicios .main-nav .nav-group .link-btn,
	body.page-servicios .main-nav .nav-group .categories-menu summary,
	body.page-servicios .cart-link,
	body.page-servicios .repair-link {
		min-width: 108px !important;
		padding: 0 12px !important;
		font-size: 0.8rem !important;
	}

	body.page-servicios .main-nav .header-logo-link {
		width: min(500px, 58vw) !important;
		height: 78px !important;
	}
}

@media (max-width: 1024px) {
	.service-card {
		grid-template-columns: minmax(200px, 238px) minmax(0, 1fr);
		gap: 12px;
	}

	.service-card h3 {
		font-size: 1.1rem;
	}

	.service-card p {
		font-size: 0.92rem;
	}
}

@media (max-width: 860px) {
	.service-card {
		padding: 10px;
		grid-template-columns: 1fr;
		gap: 10px;
	}

	.service-card:nth-child(even) .service-media {
		order: 0;
	}

	.service-media img {
		aspect-ratio: 16 / 9;
	}

	.services-cta {
		padding: 14px 12px;
	}

	.services-cta-actions .btn {
		min-width: 0;
		width: 100%;
	}

	body.has-catalog-tools .header-tools.container {
		position: static !important;
		top: auto !important;
		z-index: auto !important;
	}

	.filter-panel.admin-products-panel {
		position: static !important;
		top: auto !important;
		z-index: auto !important;
	}
}

/* Product card WhatsApp buy button */
#catalogGrid .product-meta-grid .product-actions,
.product-grid .product-body .product-meta-grid .product-actions {
	display: grid;
	gap: 6px;
}

#catalogGrid .product-meta-grid .product-actions form,
.product-grid .product-body .product-meta-grid .product-actions form {
	margin: 0;
}

#catalogGrid .product-meta-grid .product-actions .buy-whatsapp-btn,
.product-grid .product-body .product-meta-grid .product-actions .buy-whatsapp-btn {
	width: 100%;
	min-height: 34px;
	padding: 8px 10px;
	gap: 6px;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

#catalogGrid .product-meta-grid .product-actions .buy-whatsapp-btn .wa-icon-svg,
.product-grid .product-body .product-meta-grid .product-actions .buy-whatsapp-btn .wa-icon-svg {
	width: 15px;
	height: 15px;
}

@media (max-width: 560px) {
	#catalogGrid .product-meta-grid .product-actions .buy-whatsapp-btn,
	.product-grid .product-body .product-meta-grid .product-actions .buy-whatsapp-btn {
		min-height: 32px;
		font-size: 0.76rem;
	}
}

/* Final lock: title -> price -> actions (all breakpoints) */
#catalogGrid .product-body .product-meta-grid,
.product-grid .product-body .product-meta-grid {
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	gap: 4px !important;
	margin-top: auto !important;
}

#catalogGrid .product-body .product-meta-grid .price-original-spacer,
.product-grid .product-body .product-meta-grid .price-original-spacer {
	display: none !important;
}

#catalogGrid .product-body .product-meta-grid .price.price-original,
.product-grid .product-body .product-meta-grid .price.price-original {
	order: 1 !important;
	position: static !important;
	left: auto !important;
	top: auto !important;
	right: auto !important;
	grid-area: auto !important;
	margin: 0 !important;
}

#catalogGrid .product-body .product-meta-grid .price.price-main,
#catalogGrid .product-body .product-meta-grid .price.price-offer,
.product-grid .product-body .product-meta-grid .price.price-main,
.product-grid .product-body .product-meta-grid .price.price-offer {
	order: 2 !important;
	grid-area: auto !important;
	margin: 0 !important;
}

#catalogGrid .product-body .product-meta-grid .in-cart-badge,
.product-grid .product-body .product-meta-grid .in-cart-badge {
	order: 3 !important;
	position: static !important;
	left: auto !important;
	top: auto !important;
	right: auto !important;
	grid-area: auto !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	display: none !important;
	visibility: hidden !important;
}

#catalogGrid .product-card.in-cart .product-body .product-meta-grid .in-cart-badge,
.product-grid .product-card.in-cart .product-body .product-meta-grid .in-cart-badge {
	display: flex !important;
	visibility: visible !important;
}

#catalogGrid .product-body .product-meta-grid .product-actions,
.product-grid .product-body .product-meta-grid .product-actions {
	order: 4 !important;
	grid-area: auto !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 2px 0 0 !important;
}

#catalogGrid .product-body .product-meta-grid .product-actions form,
.product-grid .product-body .product-meta-grid .product-actions form {
	display: grid !important;
	grid-template-columns: 1fr !important;
	justify-items: stretch !important;
	width: 100% !important;
}

#catalogGrid .product-body .product-meta-grid .add-cart-btn,
#catalogGrid .product-body .product-meta-grid .buy-whatsapp-btn,
.product-grid .product-body .product-meta-grid .add-cart-btn,
.product-grid .product-body .product-meta-grid .buy-whatsapp-btn {
	width: 100% !important;
	min-width: 0 !important;
	max-width: none !important;
}

/* Admin services editor */
.auth-help {
	margin: 2px 0 0;
	font-size: 0.82rem;
	font-weight: 700;
	color: #3f5e9f;
}

.admin-services-card h2 {
	margin-top: 0;
	margin-bottom: 10px;
}

.admin-services-config-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin-bottom: 12px;
}

.admin-services-config-grid .field.field-wide {
	grid-column: 1 / -1;
}

.admin-services-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-top: 8px;
	margin-bottom: 10px;
}

.admin-services-list {
	display: grid;
	gap: 10px;
}

.admin-service-row {
	padding: 10px;
	border-radius: 12px;
	border: 1px solid #cfe0ff;
	background: linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%);
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
}

.admin-service-title {
	grid-column: 1 / -1;
	font-size: 0.9rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #1c4ea7;
}

.admin-service-row .field {
	margin: 0;
}

.admin-service-row .field.field-wide {
	grid-column: 1 / -1;
}

.admin-service-actions {
	grid-column: 1 / -1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

@media (max-width: 860px) {
	.admin-services-config-grid {
		grid-template-columns: 1fr;
	}

	.admin-service-row {
		grid-template-columns: 1fr;
	}
}

/* ===== Admin Expansion 2026-03 ===== */
.admin-products-panel,
.filter-panel.admin-products-panel {
	position: static !important;
	top: auto !important;
}

.admin-settings-card,
.admin-media-upload-card,
.admin-media-grid-card,
.admin-backups-card,
.admin-trash-card,
.admin-validation-card,
.admin-mobile-quick-card,
.admin-pagination-card {
	padding: 18px;
	border-radius: 16px;
	border: 1px solid #d5dff2;
	background: #f8fbff;
	margin-bottom: 14px;
}

@media (min-width: 861px) {
	.admin-mobile-quick-card {
		display: none;
	}
}

.admin-settings-grid,
.admin-mobile-quick-grid,
.admin-media-upload-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.admin-settings-grid .field.field-wide,
.admin-mobile-quick-grid .field.field-wide,
.admin-media-upload-grid .field.field-wide {
	grid-column: 1 / -1;
}

.admin-settings-actions,
.admin-media-actions,
.admin-backup-actions,
.admin-trash-actions {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
}

.admin-media-filters {
	display: grid;
	grid-template-columns: minmax(220px, 1.8fr) minmax(220px, 1fr);
	gap: 12px;
}

.admin-media-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 12px;
}

.admin-media-item {
	border: 1px solid #d3def2;
	border-radius: 14px;
	background: #ffffff;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.admin-media-thumb-wrap {
	aspect-ratio: 1 / 1;
	background: #eef3ff;
	display: grid;
	place-items: center;
}

.admin-media-thumb-wrap img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.admin-media-body {
	padding: 10px;
	display: grid;
	gap: 6px;
}

.admin-media-body h3 {
	font-size: 0.95rem;
	margin: 0;
}

.admin-media-body .small {
	font-size: 0.78rem;
}

.admin-backups-list,
.admin-trash-list {
	display: grid;
	gap: 10px;
}

.admin-backup-row,
.admin-trash-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 10px;
	padding: 10px;
	border-radius: 12px;
	border: 1px solid #d7e2f6;
	background: #fff;
}

.admin-bulk-toolbar {
	display: grid;
	grid-template-columns: auto minmax(160px, 1fr) minmax(170px, 1fr) minmax(130px, 130px) minmax(170px, 1fr) minmax(170px, 1fr) auto;
	gap: 8px;
	align-items: center;
	margin-bottom: 10px;
}

.admin-autosave-toolbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 10px;
	border: 1px dashed #c4d4f5;
	border-radius: 12px;
	background: #fff;
	margin-bottom: 12px;
}

.admin-products-table .col-select {
	width: 44px;
}

.admin-products-table td.cell-select {
	text-align: center;
	vertical-align: middle;
}

.admin-products-table td.cell-offer .admin-inline-field[type="datetime-local"] {
	font-size: 0.74rem;
	padding: 5px 6px;
	margin-top: 4px;
}

.admin-offer-status,
.admin-schedule-status {
	display: inline-flex;
	padding: 4px 8px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	border: 1px solid transparent;
	margin-top: 6px;
}

.status-programado {
	background: #eef2ff;
	color: #1d3ea8;
	border-color: #becbff;
}

.status-programada {
	background: #eef2ff;
	color: #1d3ea8;
	border-color: #becbff;
}

.status-en-curso,
.status-en-curso {
	background: #eaf9ef;
	color: #17653f;
	border-color: #b7e5ca;
}

.status-finalizado {
	background: #f5f6fa;
	color: #4d5772;
	border-color: #d8deef;
}

.status-finalizada {
	background: #f5f6fa;
	color: #4d5772;
	border-color: #d8deef;
}

.status-inactivo {
	background: #fff1f1;
	color: #a02727;
	border-color: #f0bcbc;
}

.status-sin-programar {
	background: #f3f6ff;
	color: #2c4f9e;
	border-color: #cedbf9;
}

.status-sin-oferta {
	background: #f3f6ff;
	color: #2c4f9e;
	border-color: #cedbf9;
}

.status-activa {
	background: #eaf9ef;
	color: #17653f;
	border-color: #b7e5ca;
}

.admin-validation-card h2 {
	margin-top: 0;
}

.admin-validation-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 8px;
}

.admin-validation-grid p {
	margin: 0;
	padding: 10px;
	border-radius: 10px;
	background: #fff;
	border: 1px solid #d9e2f5;
	font-weight: 700;
}

.admin-validation-inline {
	margin: 6px 0 0;
	font-size: 0.76rem;
	color: #a94141;
	font-weight: 700;
}

.admin-pagination-card {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
}

.admin-pagination-meta {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	font-weight: 700;
}

.admin-pagination-actions {
	display: flex;
	gap: 8px;
}

.btn.is-disabled {
	pointer-events: none;
	opacity: 0.55;
}

.admin-category-row {
	cursor: grab;
}

.admin-category-row.is-hidden-category {
	opacity: 0.8;
	border-style: dashed;
}

.admin-category-drag {
	font-size: 1.1rem;
	color: #2e4d96;
	padding: 4px 8px;
	border: 1px solid #c7d6f6;
	border-radius: 8px;
	background: #f4f8ff;
}

.admin-category-visibility {
	display: inline-flex;
	padding: 3px 8px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
	background: #edf2ff;
	color: #2f4a90;
}

.admin-category-row.is-dragging {
	opacity: 0.55;
}

@media (max-width: 1080px) {
	.admin-bulk-toolbar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.admin-validation-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.admin-settings-grid,
	.admin-mobile-quick-grid,
	.admin-media-upload-grid,
	.admin-media-filters {
		grid-template-columns: minmax(0, 1fr);
	}

	.admin-backup-row,
	.admin-trash-row,
	.admin-pagination-card,
	.admin-autosave-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.admin-bulk-toolbar {
		grid-template-columns: minmax(0, 1fr);
	}

	#adminProductsTable .col-select {
		width: auto;
	}

	.admin-products-table td.cell-select {
		text-align: left;
	}
}

/* ===== Admin Products Layout Stabilization (2026-03-22) ===== */
body.page-admin-productos .section-header .admin-header-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

body.page-admin-productos .admin-category-autocomplete {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 30px;
	gap: 6px;
	align-items: center;
}

body.page-admin-productos .admin-category-reset {
	width: 30px;
	min-width: 30px;
	height: 34px;
	padding: 0;
	font-size: 0.95rem;
	font-weight: 900;
}

body.page-admin-productos .admin-bulk-toolbar {
	display: grid;
	grid-template-columns: auto repeat(5, minmax(140px, 1fr)) auto;
	gap: 8px;
	align-items: center;
}

body.page-admin-productos .admin-products-grid-card {
	padding: 12px;
}

body.page-admin-productos .admin-products-table-wrap {
	width: 100%;
	overflow-x: auto;
	overflow-y: visible;
	border: 1px solid #d5dff2;
	border-radius: 14px;
	background: #ffffff;
}

body.page-admin-productos .admin-products-table {
	width: 100%;
	min-width: 1360px;
	table-layout: fixed;
}

body.page-admin-productos .admin-products-table th,
body.page-admin-productos .admin-products-table td {
	vertical-align: top;
	padding: 9px 7px;
	overflow: visible;
}

body.page-admin-productos .admin-products-table th {
	white-space: nowrap;
	font-size: 0.78rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

body.page-admin-productos .admin-products-table .col-select {
	width: 42px;
}

body.page-admin-productos .admin-products-table .col-id {
	width: 56px;
}

body.page-admin-productos .admin-products-table .col-thumb {
	width: 82px;
}

body.page-admin-productos .admin-products-table .col-name {
	width: 380px;
}

body.page-admin-productos .admin-products-table .col-category {
	width: 240px;
}

body.page-admin-productos .admin-products-table .col-active {
	width: 96px;
}

body.page-admin-productos .admin-products-table td.cell-select,
body.page-admin-productos .admin-products-table td.cell-id,
body.page-admin-productos .admin-products-table td.cell-thumb {
	vertical-align: middle;
	text-align: center;
}

body.page-admin-productos .admin-products-table .admin-inline-field {
	width: 100%;
	min-width: 0;
	height: 34px;
	padding: 6px 8px;
	font-size: 0.84rem;
}

body.page-admin-productos .admin-products-table .cell-name .admin-inline-name {
	min-width: 0 !important;
}

body.page-admin-productos .admin-products-table .cell-category {
	position: relative;
}

body.page-admin-productos .admin-row-category-picker {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 30px;
	gap: 6px;
	margin-bottom: 6px;
}

body.page-admin-productos .admin-row-category-reset {
	min-width: 30px;
	width: 30px;
	height: 34px;
	padding: 0;
}

body.page-admin-productos .admin-row-category-results {
	z-index: 95;
}

body.page-admin-productos .admin-validation-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1320px) {
	body.page-admin-productos .admin-bulk-toolbar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 1080px) {
	body.page-admin-productos .admin-validation-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-products-table {
		min-width: 0;
	}

	body.page-admin-productos .admin-products-table-wrap {
		border: 0;
		background: transparent;
	}

	body.page-admin-productos .admin-products-table tr[data-admin-product-row] {
		gap: 7px;
		padding: 10px;
	}

	body.page-admin-productos .admin-products-table td {
		grid-template-columns: 88px 1fr;
		gap: 6px;
	}

	body.page-admin-productos .admin-actions-cell {
		grid-template-columns: repeat(4, 32px);
		grid-auto-rows: 32px;
	}

	body.page-admin-productos .admin-actions-cell .btn,
	body.page-admin-productos .admin-actions-cell .icon-btn {
		width: 32px;
		height: 32px;
		min-width: 32px;
	}
}

/* ===== Admin Products Adaptive Grid Modes ===== */
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table {
	min-width: 1360px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table {
	min-width: 1220px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-name {
	width: 320px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-category {
	width: 210px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table {
	min-width: 1080px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table th,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table td {
	padding: 8px 6px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-thumb {
	width: 72px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-name {
	width: 270px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-category {
	width: 180px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-active {
	width: 84px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-inline-field {
	font-size: 0.79rem;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] {
	overflow: visible;
	border: 0;
	background: transparent;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table {
	min-width: 0;
	border-collapse: separate;
	border-spacing: 0 10px;
	table-layout: auto;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table colgroup,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table thead {
	display: none;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tbody {
	display: grid;
	gap: 10px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tr[data-admin-product-row] {
	display: grid;
	gap: 8px;
	padding: 10px;
	border: 1px solid #c7dafb;
	border-radius: 12px;
	background: #f8fbff;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tr[data-admin-no-results-row] {
	display: block;
	padding: 10px;
	border-radius: 10px;
	border: 1px dashed #c6d9fc;
	background: #f7faff;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tr[data-admin-no-results-row] td {
	display: block;
	border: 0;
	padding: 0;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td {
	display: grid;
	grid-template-columns: 92px 1fr;
	gap: 8px;
	border: 0;
	padding: 0;
	overflow: visible;
	align-items: center;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td::before {
	content: attr(data-label);
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #2453ae;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td.cell-select,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td.cell-id,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td.cell-thumb {
	text-align: left;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td.cell-thumb .admin-product-thumb {
	margin: 0;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table .cell-name .admin-inline-field {
	min-width: 0 !important;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell {
	display: grid !important;
	grid-template-columns: repeat(4, 32px);
	grid-auto-rows: 32px;
	gap: 6px;
	justify-content: start;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell::before {
	display: none;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .btn,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .icon-btn {
	width: 32px;
	height: 32px;
	min-width: 32px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .quick-edit-state {
	grid-column: 1 / -1;
	min-height: 16px;
}

body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-results {
	position: relative;
	top: auto;
	left: auto;
	right: auto;
	margin-top: 6px;
	z-index: 1;
}

@media (max-width: 620px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td {
		grid-template-columns: 84px 1fr;
		gap: 6px;
	}
}

/* ===== Admin Products UI Compact 2026-03-22 ===== */
body.page-admin-productos .site-content.container {
	width: min(1750px, 98.7vw);
	max-width: none;
}

body.page-admin-productos .section-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
}

body.page-admin-productos .section-header h1 {
	margin: 0;
	font-size: 1.45rem;
}

body.page-admin-productos .section-header .admin-header-actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

body.page-admin-productos .section-header .admin-header-actions .btn {
	min-height: 34px;
	padding: 0 12px;
	font-size: 0.78rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

body.page-admin-productos .admin-mobile-quick-card,
body.page-admin-productos .admin-validation-card,
body.page-admin-productos .admin-products-grid-card,
body.page-admin-productos .admin-pagination-card,
body.page-admin-productos .filter-panel.admin-products-panel {
	margin-bottom: 10px;
	padding: 11px 12px;
	border-radius: 14px;
}

body.page-admin-productos .admin-collapsible-panel {
	border: 1px solid #d5e2f6;
	border-radius: 12px;
	background: #ffffff;
}

body.page-admin-productos .admin-collapsible-panel > summary {
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	min-height: 38px;
	padding: 8px 10px;
	cursor: pointer;
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #1f4e9f;
}

body.page-admin-productos .admin-collapsible-panel > summary::-webkit-details-marker {
	display: none;
}

body.page-admin-productos .admin-collapsible-panel > summary::after {
	content: '▾';
	font-size: 0.84rem;
	line-height: 1;
	transition: transform 0.2s ease;
}

body.page-admin-productos .admin-collapsible-panel[open] > summary::after {
	transform: rotate(180deg);
}

body.page-admin-productos .admin-collapsible-panel > form,
body.page-admin-productos .admin-collapsible-panel > .admin-tools-panel-grid,
body.page-admin-productos .admin-collapsible-panel > .admin-validation-grid {
	padding: 8px 10px 10px;
	border-top: 1px solid #e3eaf8;
}

body.page-admin-productos .admin-tools-panel-grid {
	display: grid;
	gap: 10px;
}

body.page-admin-productos .admin-products-filters label {
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

body.page-admin-productos .admin-products-filters input,
body.page-admin-productos .admin-products-filters select,
body.page-admin-productos .admin-products-filters button {
	height: 34px;
	font-size: 0.82rem;
}

body.page-admin-productos .catalog-count[data-admin-result-count] {
	font-size: 0.84rem;
	font-weight: 900;
}

body.page-admin-productos .admin-validation-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 8px;
}

body.page-admin-productos .admin-validation-grid p {
	margin: 0;
	padding: 8px 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	font-size: 0.78rem;
	font-weight: 800;
	border-radius: 10px;
	background: #f7faff;
	border: 1px solid #dbe6fb;
}

body.page-admin-productos .admin-validation-grid p strong {
	font-size: 0.9rem;
}

body.page-admin-productos .admin-bulk-toolbar {
	grid-template-columns: auto minmax(170px, 220px) minmax(0, 1fr) auto;
	gap: 8px;
	align-items: center;
}

body.page-admin-productos .admin-bulk-toolbar .checkbox-line {
	white-space: nowrap;
	font-size: 0.78rem;
	font-weight: 800;
}

body.page-admin-productos .admin-bulk-toolbar select,
body.page-admin-productos .admin-bulk-toolbar input,
body.page-admin-productos .admin-bulk-toolbar button {
	height: 34px;
	font-size: 0.8rem;
}

body.page-admin-productos .admin-bulk-dynamic {
	display: grid;
	grid-template-columns: minmax(180px, 1fr) minmax(130px, 150px) auto;
	gap: 8px;
	align-items: center;
	min-width: 0;
}

body.page-admin-productos .admin-bulk-dynamic.is-hidden,
body.page-admin-productos .admin-bulk-field.is-hidden,
body.page-admin-productos .admin-bulk-dates.is-hidden {
	display: none !important;
}

body.page-admin-productos .admin-bulk-dates {
	border: 1px solid #d5e1f8;
	border-radius: 10px;
	background: #f7faff;
	min-width: 0;
}

body.page-admin-productos .admin-bulk-dates > summary {
	list-style: none;
	cursor: pointer;
	min-height: 32px;
	display: flex;
	align-items: center;
	padding: 0 10px;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: #24519e;
}

body.page-admin-productos .admin-bulk-dates > summary::-webkit-details-marker {
	display: none;
}

body.page-admin-productos .admin-bulk-dates-grid {
	display: grid;
	gap: 6px;
	padding: 0 8px 8px;
}

body.page-admin-productos .admin-bulk-dates-grid input {
	height: 32px;
	font-size: 0.74rem;
}

body.page-admin-productos .admin-autosave-toolbar {
	padding: 8px 10px;
	margin-bottom: 10px;
}

body.page-admin-productos .admin-autosave-toolbar .help-text {
	margin: 0;
	font-size: 0.76rem;
}

body.page-admin-productos .admin-products-table-wrap {
	border-radius: 12px;
}

body.page-admin-productos .admin-products-table th {
	font-size: 0.74rem;
}

body.page-admin-productos .admin-products-table .col-name {
	width: 420px;
}

body.page-admin-productos .admin-products-table .col-category {
	width: 250px;
}

body.page-admin-productos .admin-products-table td {
	padding-top: 8px;
	padding-bottom: 8px;
}

body.page-admin-productos .admin-pagination-card {
	padding-top: 10px;
	padding-bottom: 10px;
}

@media (max-width: 1360px) {
	body.page-admin-productos .admin-bulk-toolbar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	body.page-admin-productos .admin-bulk-dynamic {
		grid-template-columns: minmax(0, 1fr);
	}

	body.page-admin-productos .admin-validation-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .site-content.container {
		width: min(100%, 99vw);
	}

	body.page-admin-productos .admin-collapsible-panel > summary {
		min-height: 36px;
		font-size: 0.74rem;
	}

	body.page-admin-productos .admin-validation-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	body.page-admin-productos .admin-bulk-toolbar {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (min-width: 861px) {
	body.page-admin-productos .admin-bulk-toolbar {
		display: flex !important;
		flex-wrap: wrap;
		align-items: center;
		justify-content: flex-start;
		gap: 8px 10px;
	}

	body.page-admin-productos .admin-bulk-toolbar .checkbox-line {
		flex: 0 0 auto;
		margin-right: 2px;
	}

	body.page-admin-productos .admin-bulk-toolbar > select[data-admin-bulk-action] {
		flex: 0 0 178px;
		max-width: 178px;
		min-width: 160px;
	}

	body.page-admin-productos .admin-bulk-toolbar > .admin-bulk-dynamic {
		flex: 1 1 380px;
		min-width: 280px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 8px;
	}

	body.page-admin-productos .admin-bulk-toolbar > .admin-bulk-dynamic.is-hidden {
		display: none !important;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-field-category {
		flex: 0 1 220px;
		min-width: 160px;
		max-width: 240px;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-field-offer {
		flex: 0 0 118px;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-field-offer input {
		width: 118px;
		min-width: 0;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-dates {
		flex: 0 1 auto;
		width: auto;
		min-width: 165px;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-dates > summary {
		min-height: 32px;
		padding-inline: 10px;
		white-space: nowrap;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-dates-grid {
		grid-template-columns: repeat(2, minmax(148px, 164px));
		gap: 6px;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-dates-grid input {
		width: 100%;
	}

	body.page-admin-productos .admin-bulk-toolbar > button[type='submit'] {
		flex: 0 0 auto;
		min-width: 96px;
		padding-inline: 12px;
	}
}

/* ===== Desktop dynamic layout polish (admin productos) ===== */
@media (min-width: 861px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table {
		min-width: 1320px;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table {
		min-width: 1160px;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table {
		min-width: 1020px;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-name {
		width: clamp(300px, 31vw, 460px);
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-category {
		width: clamp(200px, 18vw, 270px);
	}
}

body.page-admin-productos .admin-validation-chip {
	appearance: none;
	border: 1px solid #d2def5;
	background: #f4f8ff;
	color: #1b3f82;
	border-radius: 12px;
	padding: 8px 12px;
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	font-weight: 700;
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
}

body.page-admin-productos .admin-validation-chip span {
	font-size: 0.78rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

body.page-admin-productos .admin-validation-chip strong {
	min-width: 28px;
	height: 28px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
	border: 1px solid #d4e1fb;
	color: #1a4a9f;
	font-size: 0.78rem;
}

body.page-admin-productos .admin-validation-chip:hover {
	transform: translateY(-1px);
	box-shadow: 0 7px 18px rgba(21, 63, 142, 0.12);
}

body.page-admin-productos .admin-validation-chip.is-active {
	border-color: #1f66dc;
	background: linear-gradient(180deg, #2f78ee 0%, #1d58bc 100%);
	color: #ffffff;
	box-shadow: 0 10px 24px rgba(26, 79, 171, 0.28);
}

body.page-admin-productos .admin-validation-chip.is-active strong {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.38);
	color: #ffffff;
}

body.page-admin-productos .admin-validation-reset {
	justify-self: end;
	white-space: nowrap;
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-validation-reset {
		justify-self: stretch;
		width: 100%;
	}
}

/* Admin productos: grilla escritorio canonica (sin duplicados ni solapes) */
@media (min-width: 861px) {
	body.page-admin-productos .admin-products-table .col-price,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-price,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-price,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-price {
		width: 96px !important;
	}

	body.page-admin-productos .admin-products-table .col-offer,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-offer,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-offer,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-offer {
		width: 96px !important;
	}

	body.page-admin-productos .admin-products-table .col-actions,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-actions,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-actions,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-actions {
		width: 212px !important;
	}

	body.page-admin-productos .admin-products-table td.cell-price,
	body.page-admin-productos .admin-products-table td.cell-offer {
		display: table-cell !important;
		vertical-align: middle !important;
	}

	body.page-admin-productos .admin-products-table td.cell-price > :not([data-quick-field='price']),
	body.page-admin-productos .admin-products-table td.cell-offer > :not([data-quick-field='offer_price']) {
		display: none !important;
	}

	body.page-admin-productos .admin-products-table td.cell-price > .admin-inline-field[data-quick-field='price'],
	body.page-admin-productos .admin-products-table td.cell-offer > .admin-inline-field[data-quick-field='offer_price'] {
		width: 100% !important;
		min-width: 0 !important;
		max-width: 96px !important;
	}

	body.page-admin-productos .admin-products-table td.admin-actions-cell {
		padding-left: 4px !important;
		padding-right: 4px !important;
		vertical-align: middle !important;
	}

	body.page-admin-productos .admin-actions-cell .admin-actions-icons {
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center;
		gap: 4px !important;
	}

	body.page-admin-productos .admin-actions-cell .admin-actions-icons .inline-form {
		display: inline-flex;
		margin: 0;
	}

	body.page-admin-productos .admin-actions-cell .admin-actions-icons .btn,
	body.page-admin-productos .admin-actions-cell .admin-actions-icons .icon-btn,
	body.page-admin-productos .admin-actions-cell .admin-actions-icons .admin-save-btn {
		width: 30px !important;
		height: 30px !important;
		min-width: 30px !important;
		padding: 0 !important;
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

body.page-admin-productos .admin-actions-cell .quick-edit-state,
body.page-admin-productos .admin-actions-cell .admin-row-dirty-badge {
	display: none !important;
}
}

/* Admin filtros productos: layout limpio */
body.page-admin-productos .admin-products-filters {
	display: grid !important;
	grid-template-columns: minmax(260px, 1.7fr) minmax(220px, 1.25fr) minmax(130px, 0.62fr) auto;
	gap: 10px;
	align-items: end;
}

body.page-admin-productos .admin-products-filters .filters-divider {
	display: none !important;
}

body.page-admin-productos .admin-products-filters .search-block,
body.page-admin-productos .admin-products-filters .category-block,
body.page-admin-productos .admin-products-filters .status-block {
	min-width: 0;
}

body.page-admin-productos .admin-products-filters .filter-actions {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	white-space: nowrap;
}

@media (max-width: 1320px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	body.page-admin-productos .admin-products-filters .filter-actions {
		grid-column: 1 / -1;
		justify-content: space-between;
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: minmax(0, 1fr) !important;
	}
}

/* ===== ADMIN FILTER VISIBILITY FIX (append-last) ===== */
body.page-admin-productos #adminProductsTable tr[data-admin-product-row].is-hidden,
body.page-admin-productos #adminProductsTable tr[data-admin-no-results-row].is-hidden {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

@media (max-width: 980px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] #adminProductsTable tr[data-admin-product-row]:not(.is-hidden) {
		display: grid !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] #adminProductsTable tr[data-admin-no-results-row]:not(.is-hidden) {
		display: block !important;
	}
}

/* ===== MOBILE CATALOG FILTER VISIBILITY FIX (append-last) ===== */
body.page-productos #catalogGrid .product-card.is-hidden,
body.page-productos #catalogGrid [data-product-card].is-hidden,
body.page-productos .product-grid .product-card.is-hidden,
body.page-productos .product-grid [data-product-card].is-hidden {
	display: none !important;
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

/* Catalogo: precio centrado y +15% */
#catalogGrid .product-card .product-body .product-meta-grid .price:not(.price-original),
.product-grid .product-card .product-body .product-meta-grid .price:not(.price-original) {
	width: 100% !important;
	text-align: center !important;
	margin-left: auto !important;
	margin-right: auto !important;
	font-size: calc(1em * 1.15) !important;
}

/* Admin productos: barra masiva compacta + seleccion visible de filas */
body.page-admin-productos .admin-bulk-toolbar {
	display: flex !important;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
	padding: 8px 10px;
	margin-bottom: 10px;
	border: 1px solid #d7e1f4;
	border-radius: 12px;
	background: #f9fbff;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	flex: 1 1 580px;
	min-width: 320px;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > select[data-admin-bulk-action] {
	flex: 0 0 178px;
	min-width: 160px;
	max-width: 190px;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > .admin-bulk-dynamic {
	flex: 1 1 320px;
	min-width: 230px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > .admin-bulk-dynamic.is-hidden {
	display: none !important;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > button[type='submit'] {
	flex: 0 0 auto;
	min-width: 96px;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-visible,
body.page-admin-productos .admin-bulk-toolbar .admin-bulk-only-active,
body.page-admin-productos .admin-bulk-toolbar .admin-bulk-only-inactive,
body.page-admin-productos .admin-bulk-toolbar .admin-bulk-autosave {
	flex: 0 0 auto;
	white-space: nowrap;
	font-size: 0.78rem;
	font-weight: 800;
	margin: 0;
}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-help {
	margin: 0 0 0 auto;
	font-size: 0.74rem;
	color: #4d6494;
	flex: 1 1 260px;
	text-align: right;
}

body.page-admin-productos .admin-products-table tr[data-admin-product-row].is-selected > td {
	background: #eaf4ff !important;
}

body.page-admin-productos .admin-products-table tr[data-admin-product-row].is-selected {
	box-shadow: inset 4px 0 0 #2b67d8;
}

@media (max-width: 1024px) {
	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-help {
		flex: 1 1 100%;
		text-align: left;
		margin-left: 0;
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-bulk-toolbar {
		padding: 8px;
	}

	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main,
	body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > .admin-bulk-dynamic {
		flex: 1 1 100%;
		min-width: 0;
	}

body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > select[data-admin-bulk-action],
body.page-admin-productos .admin-bulk-toolbar .admin-bulk-main > button[type='submit'] {
	flex: 1 1 calc(50% - 6px);
	max-width: none;
	min-width: 0;
}
}

/* Final lock: unify filter containers (desktop + mobile) */
body.has-catalog-tools .header-tools,
body.has-catalog-tools .header-tools.container,
.filter-panel.card-surface.header-tools,
.filter-panel.card-surface.header-tools.container {
	background:
		radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.16), transparent 44%),
		linear-gradient(180deg, var(--cf-950), var(--cf-900)) !important;
	border-color: var(--cf-800) !important;
	box-shadow: 0 12px 26px rgba(9, 32, 77, 0.22) !important;
}

body.has-catalog-tools .header-tools .filters-block label {
	color: rgba(255, 255, 255, 0.88) !important;
}

body.has-catalog-tools .header-tools .filter-actions {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px !important;
	flex-wrap: wrap !important;
}

/* Accessible hidden labels */
.sr-only {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

body.has-catalog-tools .header-tools .filter-actions .catalog-order {
	flex: 0 0 auto;
}

body.has-catalog-tools .header-tools .filter-actions .catalog-order select {
	height: 36px !important;
	min-height: 36px !important;
	padding: 0 14px !important;
	border-radius: 12px !important;
	font-size: 0.78rem !important;
	font-weight: 900 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
	color: #ffffff !important;
	background: linear-gradient(135deg, #1b62df, #1a49ad) !important;
	border: 1px solid #1a4dad !important;
	box-shadow: 0 10px 18px rgba(7, 26, 66, 0.18) !important;
}

body.has-catalog-tools .header-tools .filter-actions .catalog-order select option {
	background: var(--cf-950);
	color: #ffffff;
}

body.has-catalog-tools .header-tools .filter-actions .catalog-count {
	color: #ffffff !important;
	font-weight: 900 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
}

@media (min-width: 861px) {
	body.has-catalog-tools .header-tools .filter-actions {
		justify-content: flex-end !important;
		flex-wrap: nowrap !important;
	}

	body.has-catalog-tools .header-tools .filter-actions .catalog-order select {
		width: 20ch !important;
		min-width: 20ch !important;
		max-width: 20ch !important;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .header-tools .filter-actions {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		align-items: stretch !important;
		gap: 8px !important;
	}

	body.has-catalog-tools .header-tools .filter-actions .catalog-order,
	body.has-catalog-tools .header-tools .filter-actions .catalog-order select,
	body.has-catalog-tools .header-tools .filter-actions .btn.btn-soft,
	body.has-catalog-tools .header-tools .filter-actions .catalog-count {
		width: 100% !important;
	}

	body.has-catalog-tools .header-tools .filter-actions .catalog-count {
		text-align: center !important;
	}
}

/* Header tools: Buscar + Limpiar con el mismo look */
body.has-catalog-tools .header-tools .search-submit-btn,
body.has-catalog-tools .header-tools .filter-actions .btn.btn-soft {
	height: 36px !important;
	min-height: 36px !important;
	padding: 0 14px !important;
	border-radius: 12px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	font-weight: 900 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
	color: #ffffff !important;
	background: linear-gradient(135deg, #1b62df, #1a49ad) !important;
	border: 1px solid #1a4dad !important;
	box-shadow: 0 10px 18px rgba(7, 26, 66, 0.18) !important;
}

body.has-catalog-tools .header-tools .search-submit-btn:hover,
body.has-catalog-tools .header-tools .filter-actions .btn.btn-soft:hover {
	filter: brightness(1.05) saturate(1.05);
}

body.has-catalog-tools .header-tools .search-submit-btn:active,
body.has-catalog-tools .header-tools .filter-actions .btn.btn-soft:active {
	transform: translateY(1px);
}

/* Header filters without inline actions (search + category only) */
body.has-catalog-tools .header-catalog-filters {
	grid-template-columns: minmax(320px, 1.5fr) 1px minmax(240px, 0.9fr) !important;
}

@media (min-width: 861px) and (max-width: 1080px) {
	body.has-catalog-tools .header-catalog-filters {
		grid-template-columns: 1fr 1fr !important;
	}

	body.has-catalog-tools .header-catalog-filters .search-block {
		grid-column: 1 / -1;
	}

	body.has-catalog-tools .header-catalog-filters .filters-divider {
		display: none !important;
	}
}

/* Grid toolbar above catalog */
body.has-catalog-tools .catalog-grid-tools {
	margin: 8px 0 10px;
	padding: 7px 10px;
	background:
		radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.16), transparent 44%),
		linear-gradient(180deg, var(--cf-950), var(--cf-900));
	border: 1px solid var(--cf-800);
	border-radius: 14px;
}

body.has-catalog-tools .catalog-grid-tools .catalog-grid-tools-inner {
	display: grid;
	grid-template-columns: minmax(max-content, 1fr) minmax(28ch, 34ch) auto;
	align-items: center;
	gap: 8px 10px;
}

body.has-catalog-tools .catalog-grid-tools .catalog-count {
	margin: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0 12px;
	border-radius: 12px;
	color: #ffe8a3 !important;
	background: linear-gradient(135deg, rgba(255, 232, 163, 0.14), rgba(255, 232, 163, 0.06));
	border: 1px solid rgba(255, 232, 163, 0.34);
	box-shadow: inset 0 0 0 1px rgba(255, 232, 163, 0.08);
	font-weight: 900 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
	white-space: nowrap;
	font-size: 0.75rem;
}

body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form {
	display: inline-flex;
	align-items: center;
	justify-self: stretch;
	width: 100%;
	min-width: 28ch;
	max-width: 34ch;
}

body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form select {
	height: 36px;
	min-height: 36px;
	width: 100%;
	min-width: 28ch;
	max-width: none;
	padding: 0 12px;
	border-radius: 12px;
	font-size: 0.75rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #ffffff;
	background: linear-gradient(135deg, #1b62df, #1a49ad);
	border: 1px solid #1a4dad;
	box-shadow: 0 10px 18px rgba(7, 26, 66, 0.18);
}

body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form select option {
	background: var(--cf-950);
	color: #ffffff;
}

body.has-catalog-tools .catalog-grid-tools .catalog-grid-clear-btn {
	justify-self: end;
	white-space: nowrap;
	height: 36px;
	min-height: 36px;
	min-width: 17ch;
	padding: 0 14px;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #ffffff !important;
	background: linear-gradient(135deg, #1b62df, #1a49ad);
	border: 1px solid #1a4dad;
	box-shadow: 0 10px 18px rgba(7, 26, 66, 0.18);
}

@media (min-width: 861px) and (max-width: 1180px) {
	body.has-catalog-tools .catalog-grid-tools .catalog-grid-tools-inner {
		grid-template-columns: minmax(max-content, 1fr) minmax(24ch, 30ch) auto;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form {
		min-width: 24ch;
		max-width: 30ch;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form select {
		min-width: 24ch;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .catalog-grid-tools {
		margin: 6px 0 8px;
		padding: 6px 8px;
		border-radius: 12px;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-tools-inner {
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"count clear"
			"order order";
		align-items: center;
		gap: 6px 8px;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form {
		grid-area: order;
		justify-self: stretch;
		width: 100%;
		min-width: 0;
		max-width: none;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-order-form select {
		width: 100%;
		min-width: 0;
		height: 34px;
		min-height: 34px;
		font-size: 0.72rem;
		padding: 0 10px;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-count {
		grid-area: count;
		min-height: 32px;
		padding: 0 9px;
		font-size: 0.68rem;
		justify-content: flex-start;
		text-align: left;
	}

	body.has-catalog-tools .catalog-grid-tools .catalog-grid-clear-btn {
		grid-area: clear;
		justify-self: end;
		min-width: 0;
		height: 32px;
		min-height: 32px;
		padding: 0 10px;
		font-size: 0.68rem;
	}
}

/* Keep sticky search visually identical when it appears */
.catalog-search-sticky {
	background:
		radial-gradient(circle at 14% 18%, rgba(98, 157, 234, 0.16), transparent 44%),
		linear-gradient(180deg, var(--cf-950), var(--cf-900));
	border: 1px solid var(--cf-800);
	border-radius: 14px;
}

/* Final lock: featured products with gold border */
#catalogGrid .product-card.is-featured,
.product-grid .product-card.is-featured {
	border-color: #d4a73a !important;
	box-shadow:
		0 12px 24px rgba(33, 40, 55, 0.14),
		0 0 0 1px rgba(243, 200, 84, 0.52) inset,
		0 0 0 2px rgba(122, 86, 22, 0.25) !important;
}

#catalogGrid .product-card.is-featured .product-image,
.product-grid .product-card.is-featured .product-image {
	border-color: rgba(212, 167, 58, 0.4) !important;
}

#catalogGrid .product-card .featured-badge,
.product-grid .product-card .featured-badge {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 4;
	padding: 5px 9px;
	border-radius: 999px;
	font-size: 0.64rem;
	line-height: 1;
	font-weight: 900;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #2c2208;
	background: linear-gradient(135deg, #ffe6a0, #d4a73a 55%, #b78620);
	border: 1px solid rgba(124, 89, 21, 0.58);
	box-shadow: 0 4px 10px rgba(81, 58, 12, 0.22);
	pointer-events: none;
}

@media (min-width: 861px) {
	#catalogGrid .product-card.in-cart .featured-badge,
	.product-grid .product-card.in-cart .featured-badge {
		right: 44px;
	}

	#catalogGrid .product-card.is-new .featured-badge,
	.product-grid .product-card.is-new .featured-badge {
		top: 40px;
	}
}

@media (max-width: 860px) {
	#catalogGrid .product-card .featured-badge,
	.product-grid .product-card .featured-badge {
		top: 6px;
		right: 6px;
		padding: 4px 7px;
		font-size: 0.58rem;
	}
}

/* ===== UI refresh: header + filters + cards + accessibility ===== */
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) {
	--ui-font-family: 'Nunito Sans', 'Montserrat', sans-serif;
	--ui-font-display: 'Montserrat', 'Nunito Sans', sans-serif;
	--ui-fs-100: 0.72rem;
	--ui-fs-200: 0.8rem;
	--ui-fs-300: 0.9rem;
	--ui-fs-400: 1rem;
	--ui-fs-500: 1.12rem;
	--ui-fs-600: 1.32rem;
	--ui-fs-700: 1.7rem;
	--ui-fs-800: 2.05rem;
	--ui-panel-bg: linear-gradient(180deg, #1f4ea8 0%, #18479a 100%);
	--ui-panel-bg-soft: linear-gradient(180deg, #274f9b 0%, #1e4286 100%);
	--ui-panel-border: #5e86d8;
	--ui-btn-bg: linear-gradient(180deg, #2f69d6 0%, #2558bf 100%);
	--ui-btn-border: #2a55b2;
	--ui-btn-text: #f4f8ff;
	--ui-price-bg: linear-gradient(180deg, #eef4ff 0%, #dfeaff 100%);
	--ui-price-border: #9dbdf3;
	--ui-price-text: #133f93;
	--ui-focus: #ffd870;
	font-family: var(--ui-font-family);
}

body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) h1,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) h2,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) h3,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .eyebrow,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .catalog-count,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .btn,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav a {
	font-family: var(--ui-font-display);
}

/* Focus-visible (keyboard accessibility) */
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) a:focus-visible,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) button:focus-visible,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) input:focus-visible,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) select:focus-visible,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .btn:focus-visible,
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) [tabindex]:focus-visible {
	outline: 3px solid var(--ui-focus) !important;
	outline-offset: 2px !important;
	box-shadow: 0 0 0 2px rgba(13, 41, 98, 0.42) !important;
}

/* 1) Header normalized: only desktop/mobile patterns */
body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .site-header {
	margin-top: 10px;
}

body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .header-banner-row {
	width: min(1240px, 97vw) !important;
	margin: 0 auto !important;
}

@media (min-width: 861px) {
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
		align-items: center !important;
		gap: 8px 10px !important;
		padding: 10px 12px 11px !important;
		border-radius: 20px !important;
		border: 1px solid var(--ui-panel-border) !important;
		background: var(--ui-panel-bg) !important;
		box-shadow: 0 10px 22px rgba(11, 31, 80, 0.18) !important;
		overflow: hidden !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .header-logo-link {
		order: 1 !important;
		flex: 0 0 100% !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(540px, 54vw) !important;
		height: 84px !important;
		padding: 2px 8px !important;
		margin: 0 auto 2px !important;
		border-radius: 14px !important;
		background: rgba(8, 33, 91, 0.24) !important;
		border: 1px solid rgba(148, 187, 249, 0.28) !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .header-logo-link img {
		width: auto !important;
		height: 100% !important;
		max-width: 100% !important;
		object-fit: contain !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-toggle {
		display: none !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-group {
		order: 2 !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 8px !important;
		margin: 0 !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-group > a,
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .cart-link,
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		min-width: 106px !important;
		height: 40px !important;
		padding: 0 12px !important;
		border-radius: 999px !important;
		border: 1px solid #5d86d7 !important;
		background: linear-gradient(180deg, #1b4698, #173f88) !important;
		color: #f3f7ff !important;
		font-size: var(--ui-fs-200) !important;
		font-weight: 900 !important;
		letter-spacing: 0.03em !important;
		text-transform: uppercase !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-group > a:hover,
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .cart-link:hover,
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .repair-link:hover {
		filter: brightness(1.08);
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-group > a.is-active {
		background: #ffffff !important;
		border-color: #ffffff !important;
		color: #1f4ea8 !important;
	}
}

@media (max-width: 860px) {
	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav {
		padding: 8px !important;
		border-radius: 16px !important;
		border: 1px solid var(--ui-panel-border) !important;
		background: var(--ui-panel-bg) !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .header-logo-link {
		width: 100% !important;
		height: clamp(66px, 17vw, 90px) !important;
		padding: 2px 6px !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		object-fit: contain !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav .nav-toggle {
		min-height: 38px !important;
		border-radius: 10px !important;
		border: 1px solid #75a1f1 !important;
		background: linear-gradient(180deg, #2b5fc8, #214fa8) !important;
		color: #f4f8ff !important;
		font-size: var(--ui-fs-200) !important;
		font-weight: 900 !important;
		letter-spacing: 0.03em !important;
		text-transform: uppercase !important;
	}

	body:is(.page-home, .page-productos, .page-producto, .page-carrito, .page-servicios) .main-nav.is-open .nav-group > a {
		min-height: 38px !important;
		font-size: var(--ui-fs-200) !important;
		font-weight: 900 !important;
	}
}

/* 2) Unified filters/search bars */
body.page-productos .catalog-search-sticky,
body.page-productos .filter-panel.card-surface.header-tools,
body.page-productos .catalog-grid-tools {
	border: 1px solid var(--ui-panel-border) !important;
	background: var(--ui-panel-bg-soft) !important;
	box-shadow: 0 10px 20px rgba(12, 33, 82, 0.16) !important;
	border-radius: 14px !important;
}

@media (min-width: 861px) {
	body.page-productos .catalog-search-sticky {
		display: none !important;
	}
}

@media (max-width: 860px) {
	body.page-productos .header-tools .search-block {
		display: none !important;
	}

	body.page-productos .header-catalog-filters {
		grid-template-columns: minmax(0, 1fr) !important;
	}

	body.page-productos .header-catalog-filters .filters-divider {
		display: none !important;
	}

	body.page-productos .catalog-search-sticky {
		position: sticky;
		top: 6px;
		z-index: 45;
	}
}

/* 4) Fixed badge hierarchy */
body.page-productos #catalogGrid .product-card,
body.page-productos .product-grid .product-card {
	position: relative;
	overflow: hidden;
}

body.page-productos #catalogGrid .product-card .new-strip,
body.page-productos .product-grid .product-card .new-strip {
	z-index: 6;
}

body.page-productos #catalogGrid .product-card .card-cart-mark,
body.page-productos .product-grid .product-card .card-cart-mark {
	top: 8px !important;
	right: 8px !important;
	z-index: 7 !important;
}

body.page-productos #catalogGrid .product-card .offer-badge,
body.page-productos .product-grid .product-card .offer-badge {
	top: 10px !important;
	left: 10px !important;
	z-index: 5 !important;
}

body.page-productos #catalogGrid .product-card .featured-badge,
body.page-productos .product-grid .product-card .featured-badge {
	top: 10px !important;
	right: 46px !important;
	z-index: 5 !important;
}

body.page-productos #catalogGrid .product-card.is-new .offer-badge,
body.page-productos #catalogGrid .product-card.is-new .featured-badge,
body.page-productos .product-grid .product-card.is-new .offer-badge,
body.page-productos .product-grid .product-card.is-new .featured-badge {
	top: 40px !important;
}

/* 5) Typography scale in key catalog blocks */
body.page-productos .header-tools .filters-block label,
body.page-productos .catalog-grid-tools .catalog-count,
body.page-productos .catalog-grid-tools .catalog-grid-order-form select,
body.page-productos .catalog-grid-tools .catalog-grid-clear-btn {
	font-size: var(--ui-fs-100) !important;
	font-weight: 900 !important;
	letter-spacing: 0.04em !important;
	text-transform: uppercase !important;
}

body.page-productos #catalogGrid .product-category,
body.page-productos .product-grid .product-category {
	font-size: var(--ui-fs-100);
}

body.page-productos #catalogGrid .product-body h3,
body.page-productos .product-grid .product-body h3 {
	font-size: var(--ui-fs-500);
}

/* 6) Button consistency (catalog/detail/cart/services) */
body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn {
	min-height: 40px;
	padding: 0 14px;
	border-radius: 12px;
	font-size: var(--ui-fs-200);
	font-weight: 900;
	letter-spacing: 0.03em;
	text-transform: uppercase;
}

body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-primary,
body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-soft,
body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-whatsapp {
	border-width: 1px;
	border-style: solid;
}

body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-primary,
body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-soft {
	background: var(--ui-btn-bg);
	border-color: var(--ui-btn-border);
	color: var(--ui-btn-text);
}

body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-whatsapp {
	background: linear-gradient(180deg, #25c35b, #1ca248);
	border-color: #188a3d;
	color: #ffffff;
}

body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn.btn-danger {
	background: linear-gradient(180deg, #db5858, #c93f3f);
	border-color: #b23434;
	color: #ffffff;
}

/* 7) Price visual upgrade */
body.page-productos #catalogGrid .product-body .product-meta-grid .price.price-main,
body.page-productos #catalogGrid .product-body .product-meta-grid .price.price-offer,
body.page-productos .product-grid .product-body .product-meta-grid .price.price-main,
body.page-productos .product-grid .product-body .product-meta-grid .price.price-offer {
	border: 1px solid var(--ui-price-border) !important;
	color: var(--ui-price-text) !important;
	border-radius: 12px !important;
	padding: 5px 9px !important;
	font-size: var(--ui-fs-800) !important;
	font-weight: 900 !important;
	letter-spacing: 0.01em;
	text-align: center !important;
}

body.page-productos #catalogGrid .product-body .product-meta-grid .price.price-original,
body.page-productos .product-grid .product-body .product-meta-grid .price.price-original {
	color: #39558d;
	font-size: var(--ui-fs-400);
	font-weight: 800;
	text-align: center;
	width: 100%;
}

body.page-producto .price-group-detail .price.large,
body.page-producto .product-detail .price.large {
	font-size: clamp(2rem, 2.3vw, 2.45rem) !important;
	color: #133f93;
}

body.page-carrito .cart-head-total {
	font-size: var(--ui-fs-600);
	font-weight: 900;
	color: #103980;
}

@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-body .product-meta-grid .price.price-main,
	body.page-productos #catalogGrid .product-body .product-meta-grid .price.price-offer,
	body.page-productos .product-grid .product-body .product-meta-grid .price.price-main,
	body.page-productos .product-grid .product-body .product-meta-grid .price.price-offer {
		font-size: clamp(1.4rem, 4.8vw, 1.7rem) !important;
	}

	body:is(.page-productos, .page-producto, .page-carrito, .page-servicios) .btn {
		min-height: 36px;
		padding: 0 10px;
		font-size: 0.74rem;
	}
}

/* Desktop: evitar tarjetas gigantes cuando hay 1 o 2 resultados */
@media (min-width: 861px) {
	body.page-productos #catalogGrid.product-grid,
	body.page-productos .product-grid {
		display: grid !important;
		grid-template-columns: repeat(auto-fit, minmax(248px, 280px)) !important;
		justify-content: flex-start !important;
		align-content: start !important;
		gap: 12px !important;
	}

	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		width: 100% !important;
		max-width: 280px !important;
		justify-self: start !important;
	}
}

/* Badge + hover label alignment fix */
body.page-productos #catalogGrid .product-image::after,
body.page-productos .product-grid .product-image::after {
	content: 'Más detalles' !important;
	top: auto !important;
	bottom: 10px !important;
	left: 50% !important;
	transform: translateX(-50%) translateY(6px) !important;
	z-index: 6 !important;
}

body.page-productos #catalogGrid .product-card:hover .product-image::after,
body.page-productos .product-grid .product-card:hover .product-image::after {
	transform: translateX(-50%) translateY(0) !important;
}

body.page-productos #catalogGrid .product-card .offer-badge,
body.page-productos .product-grid .product-card .offer-badge {
	top: 10px !important;
	left: 10px !important;
	right: auto !important;
	z-index: 8 !important;
}

body.page-productos #catalogGrid .product-card .featured-badge,
body.page-productos .product-grid .product-card .featured-badge {
	top: 10px !important;
	right: 10px !important;
	left: auto !important;
	z-index: 8 !important;
}

body.page-productos #catalogGrid .product-card .card-cart-mark,
body.page-productos .product-grid .product-card .card-cart-mark {
	top: 44px !important;
	right: 10px !important;
	left: auto !important;
	z-index: 9 !important;
}

body.page-productos #catalogGrid .product-card.is-new .offer-badge,
body.page-productos #catalogGrid .product-card.is-new .featured-badge,
body.page-productos .product-grid .product-card.is-new .offer-badge,
body.page-productos .product-grid .product-card.is-new .featured-badge {
	top: 40px !important;
}

body.page-productos #catalogGrid .product-card.is-new .card-cart-mark,
body.page-productos .product-grid .product-card.is-new .card-cart-mark {
	top: 74px !important;
}

@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-image::after,
	body.page-productos .product-grid .product-image::after {
		content: none !important;
		display: none !important;
	}

	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		--mobile-badge-top: 8px;
	}

	body.page-productos #catalogGrid .product-card.is-new,
	body.page-productos .product-grid .product-card.is-new {
		--mobile-badge-top: 34px;
	}

	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		top: var(--mobile-badge-top) !important;
		left: 8px !important;
		right: auto !important;
		max-width: 104px !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
		z-index: 8 !important;
	}

	body.page-productos #catalogGrid .product-card .featured-badge,
	body.page-productos .product-grid .product-card .featured-badge {
		top: var(--mobile-badge-top) !important;
		left: auto !important;
		right: 8px !important;
		max-width: 104px !important;
		padding: 4px 7px !important;
		font-size: 0.56rem !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
		z-index: 8 !important;
	}

	body.page-productos #catalogGrid .product-card .card-cart-mark,
	body.page-productos .product-grid .product-card .card-cart-mark {
		top: calc(var(--mobile-badge-top) + 26px) !important;
		left: auto !important;
		right: 8px !important;
		z-index: 9 !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .card-cart-mark,
	body.page-productos .product-grid .product-card.is-new .card-cart-mark {
		top: calc(var(--mobile-badge-top) + 26px) !important;
	}
}

@media (max-width: 420px) {
	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		max-width: 96px !important;
		font-size: 0.54rem !important;
		padding: 4px 6px !important;
	}

	body.page-productos #catalogGrid .product-card .featured-badge,
	body.page-productos .product-grid .product-card .featured-badge {
		top: var(--mobile-badge-top) !important;
		right: 8px !important;
		left: auto !important;
		max-width: 96px !important;
		font-size: 0.54rem !important;
		padding: 4px 6px !important;
	}

	body.page-productos #catalogGrid .product-card .card-cart-mark,
	body.page-productos .product-grid .product-card .card-cart-mark {
		top: calc(var(--mobile-badge-top) + 24px) !important;
		right: 8px !important;
		left: auto !important;
	}
}

/* Mobile: anchor DESTACADO to the right edge of product-category row */
@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-card .featured-badge,
	body.page-productos .product-grid .product-card .featured-badge {
		display: none !important;
	}

	body.page-productos #catalogGrid .product-card .product-body .product-category,
	body.page-productos .product-grid .product-card .product-body .product-category {
		position: relative !important;
		display: block !important;
		min-height: 18px !important;
		width: 100% !important;
		padding-right: 78px !important;
	}

	body.page-productos #catalogGrid .product-card.is-featured .product-body .product-category::after,
	body.page-productos .product-grid .product-card.is-featured .product-body .product-category::after {
		content: 'DESTACADO';
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex: 0 0 auto;
		padding: 3px 7px;
		border-radius: 999px;
		border: 1px solid rgba(124, 89, 21, 0.56);
		background: linear-gradient(135deg, #ffe6a0, #d4a73a 55%, #b78620);
		color: #2c2208;
		font-size: 0.52rem;
		font-weight: 900;
		letter-spacing: 0.04em;
		line-height: 1;
		text-transform: uppercase;
		white-space: nowrap;
	}
}

@media (max-width: 420px) {
	body.page-productos #catalogGrid .product-card .product-body .product-category,
	body.page-productos .product-grid .product-card .product-body .product-category {
		padding-right: 74px !important;
	}

	body.page-productos #catalogGrid .product-card.is-featured .product-body .product-category::after,
	body.page-productos .product-grid .product-card.is-featured .product-body .product-category::after {
		padding: 3px 6px;
		font-size: 0.48rem;
	}
}

/* ===== UI Unification Pack 2026-03-26 (final override layer) ===== */
:root {
	--ui-font-base: 'Nunito Sans', 'Trebuchet MS', sans-serif;
	--ui-font-strong: 'Montserrat', 'Nunito Sans', sans-serif;
	--ui-fs-100: 0.72rem;
	--ui-fs-200: 0.8rem;
	--ui-fs-300: 0.9rem;
	--ui-fs-400: 1rem;
	--ui-fs-500: 1.12rem;
	--ui-fs-price: clamp(1.55rem, 2.2vw, 1.9rem);
	--ui-radius-sm: 10px;
	--ui-radius-md: 14px;
	--ui-radius-lg: 18px;
	--ui-shadow-card: 0 12px 26px rgba(16, 37, 84, 0.12);
	--ui-shadow-strong: 0 14px 30px rgba(9, 30, 74, 0.22);
}

body,
button,
input,
select,
textarea {
	font-family: var(--ui-font-base);
}

h1,
h2,
h3,
h4,
.section-header h1,
.site-footer h4,
.product-body h3,
.product-detail h1 {
	font-family: var(--ui-font-strong);
	letter-spacing: 0.01em;
}

.btn {
	min-height: 40px;
	border-radius: var(--ui-radius-md);
	font-size: var(--ui-fs-200);
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.btn.btn-sm {
	min-height: 34px;
	font-size: var(--ui-fs-100);
}

/* Header: desktop robust, mobile compact and predictable */
@media (min-width: 861px) {
	body.has-catalog-tools .site-header {
		margin-bottom: 12px;
		padding-bottom: 8px;
	}

	body.has-catalog-tools .header-banner {
		padding: 10px 0 8px;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1340px, 95vw);
		padding: 0 12px;
	}

	body.has-catalog-tools .main-nav {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(420px, 660px) minmax(0, 1fr);
		gap: 12px;
		align-items: end;
	}

	body.has-catalog-tools .main-nav .nav-group {
		display: flex !important;
		flex-wrap: wrap;
		gap: 8px;
		min-width: 0;
	}

	body.has-catalog-tools .main-nav .nav-left {
		justify-content: flex-end;
	}

	body.has-catalog-tools .main-nav .nav-right {
		justify-content: flex-start;
	}

	body.has-catalog-tools .header-logo-link {
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 6px 10px;
		min-height: 106px;
		border-radius: 20px;
	}

	body.has-catalog-tools .header-logo-link img {
		width: auto;
		max-width: 100%;
		max-height: 98px;
		object-fit: contain;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		min-height: 42px;
		padding: 0 16px;
		font-size: var(--ui-fs-300);
		letter-spacing: 0.03em;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .site-header {
		margin-bottom: 8px;
		padding-bottom: 6px;
	}

	body.has-catalog-tools .header-banner {
		padding: 8px 0 6px;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(100%, 98vw);
		padding: 0 6px;
	}

	body.has-catalog-tools .main-nav {
		display: grid !important;
		grid-template-columns: 1fr;
		gap: 8px;
	}

	body.has-catalog-tools .header-logo-link {
		order: 1;
		padding: 4px 6px;
		min-height: 84px;
	}

	body.has-catalog-tools .header-logo-link img {
		width: 100%;
		max-height: 72px;
		object-fit: contain;
	}

	body.has-catalog-tools .nav-toggle {
		order: 2;
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 40px;
		font-size: var(--ui-fs-300);
		font-weight: 900;
		letter-spacing: 0.05em;
		text-transform: uppercase;
	}

	body.has-catalog-tools .main-nav .nav-left {
		order: 3;
	}

	body.has-catalog-tools .main-nav .nav-right {
		order: 4;
	}

	body.has-catalog-tools .main-nav .nav-group {
		display: none !important;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group > a,
	body.has-catalog-tools .main-nav.is-open .nav-group .link-btn,
	body.has-catalog-tools .main-nav.is-open .cart-link,
	body.has-catalog-tools .main-nav.is-open .repair-link {
		min-height: 38px;
		padding: 0 10px;
		font-size: var(--ui-fs-200);
	}
}

/* Header tools + sticky search */
body.has-catalog-tools .catalog-search-sticky,
body.has-catalog-tools .filter-panel.card-surface.header-tools {
	border-radius: var(--ui-radius-lg);
	box-shadow: var(--ui-shadow-strong);
}

body.has-catalog-tools .header-tools .catalog-filters {
	display: grid !important;
	grid-template-columns: minmax(320px, 1.45fr) 1px minmax(250px, 1fr);
	gap: 10px 12px;
	align-items: end;
}

body.has-catalog-tools .header-tools .filters-divider {
	align-self: stretch;
}

body.has-catalog-tools .header-tools .filters-block label {
	font-size: var(--ui-fs-100);
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

body.has-catalog-tools .header-tools input,
body.has-catalog-tools .header-tools select,
body.has-catalog-tools .catalog-search-sticky input {
	height: 42px;
	border-radius: 12px;
	font-size: var(--ui-fs-500);
}

body.has-catalog-tools .header-tools .search-inline .search-submit-btn,
body.has-catalog-tools .catalog-search-sticky .search-submit-btn,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile {
	min-height: 42px;
	border-radius: 12px;
}

body.has-catalog-tools .catalog-search-sticky .search-submit-btn,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile {
	width: 42px;
	min-width: 42px;
	padding: 0;
}

body.has-catalog-tools .catalog-search-sticky .search-submit-btn .search-btn-icon,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile .cart-icon-badge {
	width: 16px;
	height: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

@media (max-width: 1080px) {
	body.has-catalog-tools .header-tools .catalog-filters {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}

	body.has-catalog-tools .header-tools .search-block {
		grid-column: 1 / -1;
	}

	body.has-catalog-tools .header-tools .filters-divider {
		display: none !important;
	}
}

@media (max-width: 860px) {
	body.has-catalog-tools .catalog-search-sticky {
		position: sticky;
		top: 8px;
		z-index: 58;
	}

	body.has-catalog-tools .header-tools .catalog-filters {
		grid-template-columns: minmax(0, 1fr);
		gap: 8px;
	}
}

/* Grid tools bar */
body.page-productos .catalog-grid-tools .catalog-grid-tools-inner {
	display: grid;
	grid-template-columns: minmax(max-content, 1fr) minmax(23ch, 28ch) auto;
	align-items: center;
	gap: 8px 10px;
}

body.page-productos .catalog-grid-tools .catalog-grid-order-form select {
	min-width: 23ch !important;
	max-width: 28ch !important;
}

body.page-productos .catalog-grid-tools .catalog-count {
	color: #ffe7a0 !important;
}

@media (max-width: 860px) {
	body.page-productos .catalog-grid-tools {
		padding: 6px 8px;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-tools-inner {
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"count clear"
			"order order";
		gap: 6px 8px;
	}

	body.page-productos .catalog-grid-tools .catalog-count {
		grid-area: count;
		min-height: 30px;
		padding: 0 8px;
		font-size: 0.67rem;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form {
		grid-area: order;
		width: 100%;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form select {
		width: 100%;
		min-width: 0 !important;
		max-width: none !important;
		height: 34px;
		font-size: 0.72rem;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-clear-btn {
		grid-area: clear;
		min-height: 30px;
		padding: 0 10px;
		font-size: 0.67rem;
	}
}

/* Product cards: fixed desktop sizing (no giant cards on few results) */
body.page-productos #catalogGrid.product-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(248px, 266px)) !important;
	justify-content: start !important;
	gap: 12px !important;
}

body.page-productos #catalogGrid .product-card {
	width: 100%;
	max-width: 266px;
	min-width: 0;
	overflow: hidden;
}

body.page-productos #catalogGrid .product-image {
	border-bottom: 1px solid #d6e3fa;
}

body.page-productos #catalogGrid .product-body {
	padding: 12px 12px 10px;
	gap: 6px;
}

body.page-productos #catalogGrid .product-body h3 {
	font-size: 1.02rem;
	line-height: 1.26;
	min-height: 2.52em;
}

body.page-productos #catalogGrid .product-meta-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	grid-template-areas:
		"old"
		"incart"
		"main"
		"actions";
	gap: 7px;
	margin-top: auto;
}

body.page-productos #catalogGrid .price-original-spacer {
	display: none !important;
}

body.page-productos #catalogGrid .product-meta-grid .price.price-original {
	grid-area: old;
	margin: 0;
	text-align: center;
	font-size: 0.94rem;
}

body.page-productos #catalogGrid .product-meta-grid .in-cart-badge {
	grid-area: incart;
	display: none;
	visibility: visible;
	min-height: 0;
	margin: 0;
}

body.page-productos #catalogGrid .product-card.in-cart .product-meta-grid .in-cart-badge {
	display: inline-flex;
}

body.page-productos #catalogGrid .product-meta-grid .price.price-main,
body.page-productos #catalogGrid .product-meta-grid .price.price-offer {
	grid-area: main;
	margin: 0;
	width: 100%;
	text-align: center;
	font-size: var(--ui-fs-price);
	font-weight: 900;
	letter-spacing: 0.01em;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

body.page-productos #catalogGrid .product-meta-grid .product-actions {
	grid-area: actions;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	padding: 0;
	margin: 0;
}

body.page-productos #catalogGrid .product-meta-grid .product-actions form {
	margin: 0;
}

body.page-productos #catalogGrid .product-meta-grid .add-cart-btn,
body.page-productos #catalogGrid .product-meta-grid .buy-whatsapp-btn {
	width: 100%;
	min-height: 36px;
	font-size: var(--ui-fs-200);
}

/* Badge stacking order (desktop + mobile) */
body.page-productos #catalogGrid .new-strip {
	z-index: 7;
}

body.page-productos #catalogGrid .offer-badge {
	z-index: 8;
	top: 8px;
	left: 8px;
}

body.page-productos #catalogGrid .featured-badge {
	z-index: 8;
	top: 8px;
	right: 8px;
}

body.page-productos #catalogGrid .card-cart-mark {
	z-index: 8;
	top: 8px;
	right: 8px;
}

body.page-productos #catalogGrid .product-card.is-new .offer-badge,
body.page-productos #catalogGrid .product-card.is-new .card-cart-mark,
body.page-productos #catalogGrid .product-card.is-new .featured-badge {
	top: 34px;
}

body.page-productos #catalogGrid .product-image::after {
	z-index: 6;
}

/* Product cards mobile: compact horizontal with no overlaps */
@media (max-width: 860px) {
	body.page-productos #catalogGrid.product-grid {
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 8px !important;
	}

	body.page-productos #catalogGrid .product-card {
		max-width: none !important;
		display: grid !important;
		grid-template-columns: minmax(116px, 128px) minmax(0, 1fr);
		grid-template-areas: "image body";
		column-gap: 10px;
		align-items: stretch;
		padding: 10px;
	}

	body.page-productos #catalogGrid .product-image {
		grid-area: image;
		aspect-ratio: 1 / 1;
		min-height: 124px;
		border-radius: 12px;
		border: 1px solid #c7d8f7;
	}

	body.page-productos #catalogGrid .product-image img {
		padding: 6px;
	}

	body.page-productos #catalogGrid .product-body {
		grid-area: body;
		padding: 0;
		min-height: 124px;
		gap: 5px;
	}

	body.page-productos #catalogGrid .product-body h3 {
		font-size: 1rem;
		line-height: 1.22;
		min-height: 0;
		-webkit-line-clamp: 2;
	}

	body.page-productos #catalogGrid .product-category {
		font-size: 0.64rem;
	}

	body.page-productos #catalogGrid .product-meta-grid {
		gap: 6px;
	}

	body.page-productos #catalogGrid .product-meta-grid .price.price-main,
	body.page-productos #catalogGrid .product-meta-grid .price.price-offer {
		font-size: clamp(1.38rem, 5.8vw, 1.64rem);
	}

	body.page-productos #catalogGrid .product-meta-grid .price.price-original {
		font-size: 0.82rem;
	}

	body.page-productos #catalogGrid .product-meta-grid .add-cart-btn,
	body.page-productos #catalogGrid .product-meta-grid .buy-whatsapp-btn {
		min-height: 34px;
		font-size: 0.72rem;
		padding: 0 8px;
	}

	body.page-productos #catalogGrid .product-meta-grid .in-cart-badge {
		font-size: 0.72rem;
		padding: 5px 8px;
	}
}

@media (max-width: 430px) {
	body.page-productos #catalogGrid .product-card {
		grid-template-columns: minmax(106px, 118px) minmax(0, 1fr);
		column-gap: 8px;
		padding: 8px;
	}

	body.page-productos #catalogGrid .product-body h3 {
		font-size: 0.93rem;
	}
}

/* Detail + cart + services alignment */
body.page-producto .product-detail-actions,
body[class*='page-producto-'] .product-detail-actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

@media (max-width: 860px) {
	body.page-producto .product-detail-actions,
	body[class*='page-producto-'] .product-detail-actions {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* Admin products: clean dynamic layout with no overlaps */
body.page-admin-productos .site-content.container {
	width: min(1820px, 98.8vw) !important;
	max-width: none !important;
}

body.page-admin-productos .admin-products-grid-card {
	padding: 10px 12px !important;
}

body.page-admin-productos .admin-products-table-wrap {
	border: 1px solid #d4e0f6;
	border-radius: 14px;
	background: #ffffff;
	overflow-x: auto;
	overflow-y: hidden;
}

body.page-admin-productos .admin-products-table {
	min-width: 1230px !important;
	table-layout: fixed !important;
}

body.page-admin-productos .admin-products-table .col-id {
	width: 58px !important;
}

body.page-admin-productos .admin-products-table .col-thumb {
	width: 78px !important;
}

body.page-admin-productos .admin-products-table .col-name {
	width: clamp(300px, 34vw, 470px) !important;
}

body.page-admin-productos .admin-products-table .col-category {
	width: clamp(190px, 19vw, 270px) !important;
}

body.page-admin-productos .admin-products-table .col-price,
body.page-admin-productos .admin-products-table .col-offer {
	width: 9ch !important;
}

body.page-admin-productos .admin-products-table .col-active {
	width: 8ch !important;
}

body.page-admin-productos .admin-products-table .col-actions {
	width: 170px !important;
}

body.page-admin-productos .admin-products-table th,
body.page-admin-productos .admin-products-table td {
	padding: 8px 6px !important;
	vertical-align: middle !important;
}

body.page-admin-productos .admin-products-table .admin-inline-field {
	height: 34px;
	font-size: 0.82rem;
}

body.page-admin-productos .admin-products-table td.cell-price .admin-inline-field,
body.page-admin-productos .admin-products-table td.cell-offer .admin-inline-field {
	max-width: 88px;
}

body.page-admin-productos .admin-products-table td.admin-actions-cell {
	display: flex !important;
	flex-direction: column;
	align-items: flex-start;
	gap: 6px;
	min-width: 0;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons {
	display: grid !important;
	grid-template-columns: repeat(3, 32px);
	grid-auto-rows: 32px;
	gap: 6px;
	align-items: center;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons .inline-form {
	margin: 0;
	display: inline-flex;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons .btn,
body.page-admin-productos .admin-actions-cell .admin-actions-icons .icon-btn,
body.page-admin-productos .admin-actions-cell .admin-actions-icons .admin-save-btn {
	width: 32px !important;
	height: 32px !important;
	min-width: 32px !important;
	padding: 0 !important;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

body.page-admin-productos .admin-actions-cell .quick-edit-state {
	display: inline-flex !important;
	margin: 0;
	min-height: 22px;
	font-size: 0.72rem;
	line-height: 1;
}

body.page-admin-productos .admin-actions-cell .quick-edit-state:empty {
	display: none !important;
}

body.page-admin-productos .admin-actions-cell .quick-edit-state + .quick-edit-state {
	display: none !important;
}

body.page-admin-productos .admin-products-table tr[data-admin-product-row].is-selected > td {
	background: #ebf5ff !important;
}

body.page-admin-productos .admin-products-table tr[data-admin-product-row].is-dirty > td {
	background: #fff9e8;
}

body.page-admin-productos .admin-products-filters {
	display: grid !important;
	grid-template-columns: minmax(260px, 1.7fr) minmax(220px, 1.2fr) minmax(120px, 0.66fr) auto;
	align-items: end;
	gap: 10px;
}

body.page-admin-productos .admin-products-filters .filters-divider {
	display: none !important;
}

body.page-admin-productos .admin-products-filters .filter-actions {
	justify-content: flex-end;
}

@media (max-width: 1180px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	body.page-admin-productos .admin-products-filters .search-block {
		grid-column: 1 / -1;
	}

	body.page-admin-productos .admin-products-filters .filter-actions {
		grid-column: 1 / -1;
		justify-content: space-between;
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: minmax(0, 1fr);
	}

	body.page-admin-productos .admin-products-table {
		min-width: 0 !important;
	}
}

/* ===== UI Fine Tune Pack 2026-03-26 (breakpoints: 1366 / 1024 / 768 / 390 / 360) ===== */

/* 1366+ desktop */
@media (min-width: 1366px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1420px, 95vw);
	}

	body.has-catalog-tools .main-nav {
		grid-template-columns: minmax(0, 1fr) minmax(460px, 690px) minmax(0, 1fr);
	}

	body.has-catalog-tools .header-logo-link {
		min-height: 112px;
	}

	body.has-catalog-tools .header-logo-link img {
		max-height: 104px;
	}

	body.page-productos #catalogGrid.product-grid {
		grid-template-columns: repeat(auto-fill, minmax(250px, 266px)) !important;
		gap: 12px !important;
	}
}

/* 1024-1365 desktop/tablet-large */
@media (min-width: 1024px) and (max-width: 1365px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1240px, 96vw);
		padding: 0 10px;
	}

	body.has-catalog-tools .main-nav {
		grid-template-columns: minmax(0, 1fr) minmax(390px, 540px) minmax(0, 1fr);
		gap: 10px;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		min-height: 40px;
		padding: 0 12px;
		font-size: 0.82rem;
	}

	body.page-productos #catalogGrid.product-grid {
		grid-template-columns: repeat(auto-fill, minmax(232px, 248px)) !important;
		gap: 11px !important;
	}

	body.page-admin-productos .admin-products-table {
		min-width: 1160px !important;
	}

	body.page-admin-productos .admin-products-table .col-name {
		width: clamp(280px, 31vw, 420px) !important;
	}

	body.page-admin-productos .admin-products-table .col-category {
		width: clamp(170px, 18vw, 240px) !important;
	}

	body.page-admin-productos .admin-products-table .col-actions {
		width: 158px !important;
	}
}

/* 768-1023 tablet */
@media (min-width: 768px) and (max-width: 1023px) {
	body.has-catalog-tools .header-banner-row {
		width: min(100%, 98vw);
		padding: 0 8px;
	}

	body.has-catalog-tools .main-nav {
		grid-template-columns: minmax(0, 1fr);
		gap: 8px;
	}

	body.has-catalog-tools .header-logo-link {
		order: 1;
		min-height: 96px;
	}

	body.has-catalog-tools .header-logo-link img {
		max-height: 84px;
	}

	body.has-catalog-tools .nav-toggle {
		order: 2;
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 40px;
	}

	body.has-catalog-tools .main-nav .nav-group {
		display: none !important;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group {
		display: grid !important;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 8px;
	}

	body.has-catalog-tools .main-nav.is-open .nav-group > a,
	body.has-catalog-tools .main-nav.is-open .nav-group .link-btn,
	body.has-catalog-tools .main-nav.is-open .cart-link,
	body.has-catalog-tools .main-nav.is-open .repair-link {
		min-height: 38px;
		padding: 0 10px;
		font-size: 0.76rem;
	}

	body.has-catalog-tools .header-tools .catalog-filters {
		grid-template-columns: minmax(0, 1fr);
		gap: 8px;
	}

	body.has-catalog-tools .header-tools .filters-divider {
		display: none !important;
	}

	body.page-productos #catalogGrid.product-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 10px !important;
	}

	body.page-productos #catalogGrid .product-card {
		max-width: none;
	}

	body.page-admin-productos .admin-products-filters {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 8px;
	}

	body.page-admin-productos .admin-products-filters .search-block,
	body.page-admin-productos .admin-products-filters .filter-actions {
		grid-column: 1 / -1;
	}
}

/* <=390 mobile */
@media (max-width: 390px) {
	body.has-catalog-tools .header-logo-link {
		min-height: 78px;
	}

	body.has-catalog-tools .header-logo-link img {
		max-height: 66px;
	}

	body.has-catalog-tools .catalog-search-sticky {
		top: 6px;
	}

	body.has-catalog-tools .catalog-search-sticky input {
		height: 40px;
		font-size: 1rem;
	}

	body.has-catalog-tools .catalog-search-sticky .search-submit-btn,
	body.has-catalog-tools .catalog-search-sticky .search-cart-mobile {
		width: 40px;
		min-width: 40px;
		min-height: 40px;
	}

	body.page-productos #catalogGrid .product-card {
		grid-template-columns: minmax(102px, 112px) minmax(0, 1fr);
		column-gap: 8px;
		padding: 8px;
	}

	body.page-productos #catalogGrid .product-image {
		min-height: 110px;
	}

	body.page-productos #catalogGrid .product-body h3 {
		font-size: 0.9rem;
	}

	body.page-productos #catalogGrid .product-meta-grid .price.price-main,
	body.page-productos #catalogGrid .product-meta-grid .price.price-offer {
		font-size: clamp(1.28rem, 6vw, 1.5rem);
	}

	body.page-productos #catalogGrid .product-meta-grid .add-cart-btn,
	body.page-productos #catalogGrid .product-meta-grid .buy-whatsapp-btn {
		min-height: 32px;
		font-size: 0.68rem;
		padding: 0 7px;
	}

	body.page-productos #catalogGrid .product-meta-grid .in-cart-badge {
		font-size: 0.68rem;
		padding: 4px 7px;
	}
}

/* <=360 very small mobile */
@media (max-width: 360px) {
	body.has-catalog-tools .main-nav.is-open .nav-group {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	body.has-catalog-tools .main-nav.is-open .nav-group > a,
	body.has-catalog-tools .main-nav.is-open .cart-link,
	body.has-catalog-tools .main-nav.is-open .repair-link {
		font-size: 0.7rem;
		padding: 0 8px;
	}

	body.page-productos #catalogGrid .product-card {
		grid-template-columns: minmax(96px, 104px) minmax(0, 1fr);
		column-gap: 7px;
	}

	body.page-productos #catalogGrid .product-meta-grid {
		grid-template-areas:
			"old"
			"incart"
			"main"
			"actions";
	}

	body.page-productos #catalogGrid .product-meta-grid .product-actions {
		grid-template-columns: minmax(0, 1fr);
		gap: 6px;
	}

	body.page-productos #catalogGrid .product-meta-grid .add-cart-btn,
	body.page-productos #catalogGrid .product-meta-grid .buy-whatsapp-btn {
		min-height: 31px;
	}
}

/* ===== Mobile Header Canonical Reset 2026-03-26 (anti-overlap) ===== */
@media (max-width: 860px) {
	body.has-catalog-tools .site-header {
		margin-top: 6px !important;
		margin-bottom: 8px !important;
		padding-bottom: 4px !important;
	}

	body.has-catalog-tools .header-banner {
		padding: 6px 0 4px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(100%, 98vw) !important;
		margin: 0 auto !important;
		padding: 0 4px !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		position: relative !important;
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		grid-template-areas:
			"logo"
			"toggle"
			"left"
			"right" !important;
		align-items: stretch !important;
		justify-items: stretch !important;
		gap: 8px !important;
		padding: 8px !important;
		border-radius: 16px !important;
		overflow: visible !important;
	}

	body.has-catalog-tools #mainNav.main-nav::before,
	body.has-catalog-tools #mainNav.main-nav::after {
		content: none !important;
		display: none !important;
	}

	body.has-catalog-tools #mainNav.main-nav > * {
		position: static !important;
		inset: auto !important;
		transform: none !important;
		min-width: 0 !important;
		max-width: 100% !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		grid-area: logo !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		height: auto !important;
		min-height: 76px !important;
		padding: 3px 6px !important;
		margin: 0 !important;
		border-radius: 12px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link img {
		display: block !important;
		width: 100% !important;
		height: auto !important;
		max-height: 68px !important;
		object-fit: contain !important;
		object-position: center !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle {
		grid-area: toggle !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		min-height: 38px !important;
		height: 38px !important;
		padding: 0 10px !important;
		margin: 0 !important;
		font-size: 0.78rem !important;
		font-weight: 900 !important;
		letter-spacing: 0.05em !important;
		line-height: 1 !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		display: none !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
		gap: 8px !important;
		align-items: stretch !important;
		justify-content: stretch !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-left {
		grid-area: left !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-right {
		grid-area: right !important;
	}

	body.has-catalog-tools #mainNav.is-open .nav-group.nav-left,
	body.has-catalog-tools #mainNav.is-open .nav-group.nav-right {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	body.has-catalog-tools #mainNav.is-open .nav-group > a,
	body.has-catalog-tools #mainNav.is-open .nav-group .link-btn,
	body.has-catalog-tools #mainNav.is-open .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav.is-open .cart-link,
	body.has-catalog-tools #mainNav.is-open .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		min-height: 36px !important;
		height: 36px !important;
		padding: 0 8px !important;
		margin: 0 !important;
		border-radius: 10px !important;
		font-size: 0.74rem !important;
		font-weight: 900 !important;
		letter-spacing: 0.03em !important;
		line-height: 1 !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
	}

	body.has-catalog-tools #mainNav.is-open .cart-pill {
		margin-left: 6px !important;
		min-width: 18px !important;
		height: 18px !important;
		padding: 0 5px !important;
		font-size: 0.68rem !important;
	}
}

@media (max-width: 390px) {
	body.has-catalog-tools #mainNav {
		gap: 7px !important;
		padding: 7px !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		min-height: 72px !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link img {
		max-height: 62px !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle {
		font-size: 0.72rem !important;
	}

	body.has-catalog-tools #mainNav.is-open .nav-group {
		gap: 6px !important;
	}

	body.has-catalog-tools #mainNav.is-open .nav-group > a,
	body.has-catalog-tools #mainNav.is-open .cart-link,
	body.has-catalog-tools #mainNav.is-open .repair-link {
		font-size: 0.68rem !important;
		padding: 0 6px !important;
	}
}

/* ===== Product Detail Price = Catalog Grid Price ===== */
body.page-producto .product-detail .price.large,
body.page-producto .product-detail .price-group-detail .price.price-offer,
body[class*='page-producto-'] .product-detail .price.large,
body[class*='page-producto-'] .product-detail .price-group-detail .price.price-offer {
	margin: 0 !important;
	width: 100% !important;
	text-align: center !important;
	font-family: var(--ui-font-strong) !important;
	font-size: var(--ui-fs-price) !important;
	font-weight: 900 !important;
	letter-spacing: 0.01em !important;
	color: var(--ui-price-text) !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}

body.page-producto .product-detail .price-group-detail .price.price-original,
body[class*='page-producto-'] .product-detail .price-group-detail .price.price-original {
	width: 100% !important;
	text-align: center !important;
	font-size: var(--ui-fs-400) !important;
	font-weight: 800 !important;
	color: #39558d !important;
}

@media (max-width: 860px) {
	body.page-producto .product-detail .price.large,
	body.page-producto .product-detail .price-group-detail .price.price-offer,
	body[class*='page-producto-'] .product-detail .price.large,
	body[class*='page-producto-'] .product-detail .price-group-detail .price.price-offer {
		font-size: clamp(1.4rem, 4.8vw, 1.7rem) !important;
	}
}

/* ===== Mobile UX quick fixes: image hint + compact footer ===== */
@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-image::after,
	body.page-productos .product-grid .product-image::after {
		opacity: 1 !important;
		transform: translateX(-50%) translateY(0) !important;
		top: 8px !important;
		padding: 4px 8px !important;
		font-size: 0.58rem !important;
		letter-spacing: 0.03em !important;
	}

	body.page-productos #catalogGrid .product-image:active::after,
	body.page-productos .product-grid .product-image:active::after,
	body.page-productos #catalogGrid .product-image:focus-visible::after,
	body.page-productos .product-grid .product-image:focus-visible::after {
		filter: brightness(1.08);
	}

	.site-footer {
		padding: 10px 0 4px !important;
	}

	.footer-legacy-grid {
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 6px !important;
	}

	.footer-block {
		padding: 7px 8px !important;
		border-radius: 10px !important;
	}

	.footer-block h4 {
		margin: 0 0 4px !important;
		font-size: 0.82rem !important;
	}

	.footer-contact-list {
		gap: 4px !important;
	}

	.footer-contact-list li {
		grid-template-columns: 14px 1fr !important;
		gap: 5px !important;
		font-size: 0.74rem !important;
		line-height: 1.25 !important;
	}

	.footer-icon {
		font-size: 0.8rem !important;
	}

	.footer-map-wrap iframe {
		height: 94px !important;
	}

	.footer-cta p {
		margin: 0 0 6px !important;
		font-size: 0.74rem !important;
		line-height: 1.25 !important;
	}

	.footer-whatsapp-btn {
		width: 100% !important;
		min-height: 32px !important;
		padding: 7px 8px !important;
		font-size: 0.76rem !important;
		justify-content: center !important;
	}

	.footer-copy {
		margin-top: 5px !important;
		padding-top: 5px !important;
		font-size: 0.7rem !important;
	}
}

@media (max-width: 480px) {
	.footer-map-wrap iframe {
		height: 86px !important;
	}
}

/* ===== Catalog filters visibility fix (mobile + desktop) ===== */
body.page-productos #catalogGrid .product-card.is-hidden,
body.page-productos #catalogGrid [data-product-card].is-hidden,
body.page-productos .product-grid .product-card.is-hidden,
body.page-productos .product-grid [data-product-card].is-hidden {
	display: none !important;
}

/* ===== Catalog filter transitions (smooth) ===== */
body.page-productos #catalogGrid .product-card,
body.page-productos .product-grid .product-card {
	will-change: transform, opacity;
}

body.page-productos #catalogGrid .product-card.is-filter-enter,
body.page-productos .product-grid .product-card.is-filter-enter {
	animation: catalogFilterFadeIn 0.16s ease both;
}

body.page-productos #catalogGrid .product-card.is-filter-leave,
body.page-productos .product-grid .product-card.is-filter-leave {
	opacity: 0 !important;
	transform: translateY(6px) scale(0.985) !important;
	pointer-events: none !important;
}

@keyframes catalogFilterFadeIn {
	from {
		opacity: 0;
		transform: translateY(6px) scale(0.985);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	body.page-productos #catalogGrid .product-card.is-filter-enter,
	body.page-productos .product-grid .product-card.is-filter-enter {
		animation: none !important;
	}

	body.page-productos #catalogGrid .product-card.is-filter-leave,
	body.page-productos .product-grid .product-card.is-filter-leave {
		opacity: 1 !important;
		transform: none !important;
	}
}

/* ===== Mobile tiny-width product card stability ===== */
@media (max-width: 390px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		display: grid !important;
		grid-template-columns: 98px minmax(0, 1fr) !important;
		grid-template-areas: "image body" !important;
		align-items: start !important;
		overflow: hidden !important;
	}

	body.page-productos #catalogGrid .product-image,
	body.page-productos .product-grid .product-image {
		grid-area: image !important;
		display: block !important;
		position: relative !important;
		width: 98px !important;
		min-width: 98px !important;
		max-width: 98px !important;
		height: 98px !important;
		min-height: 98px !important;
		max-height: 98px !important;
		margin: 0 !important;
		align-self: start !important;
		overflow: hidden !important;
	}

	body.page-productos #catalogGrid .product-image img,
	body.page-productos .product-grid .product-image img {
		width: 100% !important;
		height: 100% !important;
		object-fit: contain !important;
		padding: 5px !important;
	}

	body.page-productos #catalogGrid .product-body,
	body.page-productos .product-grid .product-body {
		grid-area: body !important;
		min-width: 0 !important;
		min-height: 0 !important;
		align-self: start !important;
		overflow: hidden !important;
	}
}

@media (max-width: 360px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		grid-template-columns: 92px minmax(0, 1fr) !important;
		column-gap: 7px !important;
	}

	body.page-productos #catalogGrid .product-image,
	body.page-productos .product-grid .product-image {
		width: 92px !important;
		min-width: 92px !important;
		max-width: 92px !important;
		height: 92px !important;
		min-height: 92px !important;
		max-height: 92px !important;
	}
}

/* ===== FINAL LAYOUT HOTFIX B10 (desktop header + mobile product cards) ===== */

/* Desktop header: stable two-row layout without overlap */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1280px, 96vw) !important;
		margin: 0 auto !important;
		padding: 0 8px !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		position: relative !important;
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(430px, 620px) minmax(0, 1fr) !important;
		grid-template-areas:
			"logo logo logo"
			"left left right" !important;
		row-gap: 10px !important;
		column-gap: 12px !important;
		align-items: center !important;
		padding: 8px 12px 10px !important;
		border-radius: 18px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		grid-area: logo !important;
		justify-self: center !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(560px, 56vw) !important;
		min-height: 92px !important;
		height: 92px !important;
		padding: 4px 10px !important;
		margin: 0 !important;
		border-radius: 14px !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link img {
		display: block !important;
		width: auto !important;
		height: 100% !important;
		max-width: 100% !important;
		max-height: 100% !important;
		object-fit: contain !important;
		object-position: center !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: wrap !important;
		align-items: center !important;
		gap: 8px !important;
		width: auto !important;
		min-width: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools #mainNav .nav-left {
		grid-area: left !important;
		justify-self: end !important;
		justify-content: flex-end !important;
	}

	body.has-catalog-tools #mainNav .nav-right {
		grid-area: right !important;
		justify-self: start !important;
		justify-content: flex-start !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		min-height: 40px !important;
		height: 40px !important;
		padding: 0 14px !important;
		margin: 0 !important;
		border-radius: 999px !important;
		font-size: 0.86rem !important;
		font-weight: 900 !important;
		letter-spacing: 0.03em !important;
		white-space: nowrap !important;
	}
}

/* Mobile product cards: hard reset to prevent image/text overlap */
@media (max-width: 860px) {
	body.page-productos #catalogGrid.product-grid {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 8px !important;
	}

	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		--card-media-size: clamp(102px, 30vw, 126px);
		display: grid !important;
		grid-template-columns: var(--card-media-size) minmax(0, 1fr) !important;
		grid-template-areas: "media content" !important;
		align-items: start !important;
		column-gap: 10px !important;
		row-gap: 0 !important;
		padding: 8px !important;
		overflow: hidden !important;
		position: relative !important;
	}

	body.page-productos #catalogGrid .product-image,
	body.page-productos .product-grid .product-image {
		grid-area: media !important;
		display: block !important;
		float: none !important;
		clear: none !important;
		position: relative !important;
		left: auto !important;
		top: auto !important;
		width: var(--card-media-size) !important;
		min-width: var(--card-media-size) !important;
		max-width: var(--card-media-size) !important;
		height: var(--card-media-size) !important;
		min-height: var(--card-media-size) !important;
		max-height: var(--card-media-size) !important;
		margin: 0 !important;
		align-self: start !important;
		overflow: hidden !important;
		border-radius: 10px !important;
	}

	body.page-productos #catalogGrid .product-image img,
	body.page-productos .product-grid .product-image img {
		width: 100% !important;
		height: 100% !important;
		object-fit: contain !important;
		padding: 5px !important;
	}

	body.page-productos #catalogGrid .product-body,
	body.page-productos .product-grid .product-body {
		grid-area: content !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 5px !important;
		min-width: 0 !important;
		min-height: 0 !important;
		padding: 0 !important;
		margin: 0 !important;
		align-self: start !important;
		overflow: hidden !important;
	}

	body.page-productos #catalogGrid .product-body h3,
	body.page-productos .product-grid .product-body h3 {
		margin: 0 !important;
		font-size: 0.98rem !important;
		line-height: 1.2 !important;
		min-height: 0 !important;
		-webkit-line-clamp: 2 !important;
	}
}

@media (max-width: 390px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		--card-media-size: 96px;
		column-gap: 8px !important;
	}

	body.page-productos #catalogGrid .product-body h3,
	body.page-productos .product-grid .product-body h3 {
		font-size: 0.9rem !important;
	}
}

@media (max-width: 360px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		--card-media-size: 90px;
		column-gap: 7px !important;
	}
}

/* ===== Restored from backup 26-3: desktop header layout (canonical) ===== */
/* Source: C:\PAGINA SUDOKU\_tmp_backup_26_3\tienda\assets\css\style.css */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner {
		padding: 4px 0 2px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1120px, 96vw) !important;
		margin: 0 auto !important;
		padding: 0 4px !important;
	}

	body.has-catalog-tools .main-nav {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
		align-items: center !important;
		column-gap: 12px !important;
		row-gap: 6px !important;
		padding: 6px 12px 8px !important;
		border-radius: 18px !important;
		border: 1px solid rgba(126, 172, 247, 0.5) !important;
		background: linear-gradient(180deg, #1d57b6 0%, #174ca8 100%) !important;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
		min-height: 0 !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link {
		order: 1 !important;
		flex: 0 1 100% !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(560px, 48vw) !important;
		height: 82px !important;
		margin: 0 auto !important;
		padding: 2px 4px !important;
		border-radius: 14px !important;
		background: rgba(8, 33, 90, 0.22) !important;
		border: 0 !important;
		box-shadow: none !important;
		overflow: hidden !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		object-fit: contain !important;
		object-position: center center !important;
		transform: none !important;
		transform-origin: center center !important;
	}

	body.has-catalog-tools .main-nav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group {
		order: 2 !important;
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 10px !important;
		width: auto !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools .main-nav .nav-left,
	body.has-catalog-tools .main-nav .nav-right {
		grid-column: auto !important;
		grid-row: auto !important;
		justify-self: auto !important;
		justify-content: center !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		min-width: 136px !important;
		min-height: 44px !important;
		padding: 0 16px !important;
		border-radius: 999px !important;
		border: 0 !important;
		background: rgba(8, 32, 88, 0.88) !important;
		color: #eef4ff !important;
		font-size: 0.95rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.02em !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #1e4ea4 !important;
	}

	body.has-catalog-tools .cart-pill {
		margin-left: 8px !important;
		padding: 3px 10px !important;
		font-size: 0.84rem !important;
		line-height: 1 !important;
		background: #f2f6ff !important;
		color: #1e4ea4 !important;
		border-radius: 999px !important;
	}
}

@media (min-width: 861px) and (max-width: 1140px) {
	body.has-catalog-tools .main-nav .header-logo-link {
		width: min(500px, 58vw) !important;
		height: 74px !important;
	}

	body.has-catalog-tools .main-nav .header-logo-link img {
		transform: none !important;
	}

	body.has-catalog-tools .main-nav .nav-group {
		gap: 8px !important;
	}

	body.has-catalog-tools .main-nav .nav-group > a,
	body.has-catalog-tools .main-nav .nav-group .link-btn,
	body.has-catalog-tools .main-nav .nav-group .categories-menu summary,
	body.has-catalog-tools .cart-link,
	body.has-catalog-tools .repair-link {
		min-width: 118px !important;
		min-height: 40px !important;
		padding: 0 12px !important;
		font-size: 0.84rem !important;
	}
}


/* ===== Final hotfix 2026-03-29 (append-last): desktop header + mobile offer badge ===== */
@media (min-width: 861px) {
	body.has-catalog-tools .header-banner {
		padding: 6px 0 4px !important;
	}

	body.has-catalog-tools .header-banner-row {
		width: min(1240px, 98vw) !important;
		margin: 0 auto !important;
		padding: 0 8px !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) !important;
		grid-template-areas:
			"logo logo logo"
			"left left right" !important;
		column-gap: 14px !important;
		row-gap: 10px !important;
		align-items: center !important;
		padding: 10px 16px 12px !important;
		border-radius: 20px !important;
		border: 1px solid rgba(126, 172, 247, 0.52) !important;
		background: linear-gradient(180deg, #1d57b6 0%, #174ca8 100%) !important;
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
		min-height: 0 !important;
	}

	body.has-catalog-tools #mainNav.main-nav::before,
	body.has-catalog-tools #mainNav.main-nav::after {
		display: none !important;
		content: none !important;
	}

	body.has-catalog-tools #mainNav.main-nav > * {
		position: relative !important;
		z-index: 1 !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		grid-area: logo !important;
		justify-self: center !important;
		align-self: center !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: min(620px, 52vw) !important;
		height: 102px !important;
		margin: 0 !important;
		padding: 4px 8px !important;
		border-radius: 16px !important;
		background: rgba(8, 33, 90, 0.24) !important;
		border: 0 !important;
		overflow: hidden !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link img {
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		object-fit: contain !important;
		object-position: center center !important;
		transform: none !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle {
		display: none !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		position: static !important;
		inset: auto !important;
		transform: none !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		gap: 12px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-left {
		grid-area: left !important;
		justify-content: flex-end !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-right {
		grid-area: right !important;
		justify-content: flex-start !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 8px !important;
		min-width: 134px !important;
		min-height: 44px !important;
		padding: 0 16px !important;
		border-radius: 999px !important;
		border: 0 !important;
		background: rgba(8, 32, 88, 0.88) !important;
		color: #eef4ff !important;
		font-size: 0.93rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.02em !important;
		line-height: 1 !important;
		text-transform: uppercase !important;
		white-space: nowrap !important;
		box-shadow: none !important;
	}

	body.has-catalog-tools #mainNav .nav-right .cart-link {
		min-width: 148px !important;
	}

	body.has-catalog-tools #mainNav .nav-right .repair-link {
		min-width: 176px !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a:hover,
	body.has-catalog-tools #mainNav .nav-group .link-btn:hover,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary:hover {
		filter: brightness(1.07) !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a.is-active {
		background: #ffffff !important;
		color: #1e4ea4 !important;
	}

	body.has-catalog-tools #mainNav .cart-link .nav-cart-icon {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 18px !important;
		height: 18px !important;
	}

	body.has-catalog-tools #mainNav .cart-link .cart-icon-svg {
		width: 14px !important;
		height: 14px !important;
		fill: currentColor !important;
	}

	body.has-catalog-tools #mainNav .cart-pill {
		margin-left: 4px !important;
		padding: 3px 10px !important;
		font-size: 0.84rem !important;
		line-height: 1 !important;
		background: #f2f6ff !important;
		color: #1e4ea4 !important;
		border-radius: 999px !important;
	}
}

@media (min-width: 861px) and (max-width: 1160px) {
	body.has-catalog-tools .header-banner-row {
		width: min(1220px, 99vw) !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		padding: 8px 12px 10px !important;
		column-gap: 10px !important;
		row-gap: 8px !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		width: min(540px, 60vw) !important;
		height: 88px !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		gap: 8px !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .nav-group .categories-menu summary,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		min-width: 118px !important;
		min-height: 40px !important;
		padding: 0 12px !important;
		font-size: 0.82rem !important;
	}

	body.has-catalog-tools #mainNav .nav-right .cart-link {
		min-width: 124px !important;
	}

	body.has-catalog-tools #mainNav .nav-right .repair-link {
		min-width: 144px !important;
	}
}

/* ===== MOBILE BADGES FINAL CANONICAL v2 (append-last) ===== */
@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		position: relative !important;
	}

	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		left: 8px !important;
		right: auto !important;
		bottom: auto !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		height: 24px !important;
		width: auto !important;
		max-width: 112px !important;
		padding: 0 10px !important;
		margin: 0 !important;
		border-radius: 7px !important;
		white-space: nowrap !important;
		line-height: 1 !important;
		transform: none !important;
		z-index: 30 !important;
	}

	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		left: 8px !important;
		right: auto !important;
		bottom: auto !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		height: 24px !important;
		width: auto !important;
		max-width: 112px !important;
		padding: 0 10px !important;
		margin: 0 !important;
		white-space: nowrap !important;
		line-height: 1 !important;
		transform: none !important;
		z-index: 29 !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 36px !important;
	}

	body.page-productos #catalogGrid .product-card .featured-badge,
	body.page-productos .product-grid .product-card .featured-badge {
		position: absolute !important;
		inset: auto !important;
		top: 8px !important;
		right: 8px !important;
		left: auto !important;
		bottom: auto !important;
		z-index: 28 !important;
	}
}

@media (max-width: 420px) {
	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip,
	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		height: 22px !important;
		max-width: 104px !important;
		padding: 0 8px !important;
		font-size: 0.7rem !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 33px !important;
	}
}

@media (max-width: 360px) {
	body.page-productos #catalogGrid .product-card .new-strip,
	body.page-productos .product-grid .product-card .new-strip,
	body.page-productos #catalogGrid .product-card .offer-badge,
	body.page-productos .product-grid .product-card .offer-badge {
		top: 7px !important;
		left: 7px !important;
		height: 21px !important;
		max-width: 98px !important;
		padding: 0 7px !important;
		font-size: 0.66rem !important;
	}

	body.page-productos #catalogGrid .product-card.is-new .offer-badge,
	body.page-productos .product-grid .product-card.is-new .offer-badge {
		top: 31px !important;
	}
}

/* ===== MOBILE IMAGE OFFSET FOR BADGES (append-last) ===== */
@media (max-width: 860px) {
	body.page-productos #catalogGrid .product-card .product-image,
	body.page-productos .product-grid .product-card .product-image {
		margin-top: 0 !important;
	}

	body.page-productos #catalogGrid .product-card.has-offer .product-image,
	body.page-productos .product-grid .product-card.has-offer .product-image {
		margin-top: 34px !important;
	}

	body.page-productos #catalogGrid .product-card.has-offer.is-new .product-image,
	body.page-productos .product-grid .product-card.has-offer.is-new .product-image {
		margin-top: 60px !important;
	}
}

@media (max-width: 420px) {
	body.page-productos #catalogGrid .product-card.has-offer .product-image,
	body.page-productos .product-grid .product-card.has-offer .product-image {
		margin-top: 31px !important;
	}

	body.page-productos #catalogGrid .product-card.has-offer.is-new .product-image,
	body.page-productos .product-grid .product-card.has-offer.is-new .product-image {
		margin-top: 54px !important;
	}
}

@media (max-width: 360px) {
	body.page-productos #catalogGrid .product-card.has-offer .product-image,
	body.page-productos .product-grid .product-card.has-offer .product-image {
		margin-top: 29px !important;
	}

	body.page-productos #catalogGrid .product-card.has-offer.is-new .product-image,
	body.page-productos .product-grid .product-card.has-offer.is-new .product-image {
		margin-top: 50px !important;
	}
}

/* ===== DESKTOP LAYOUT CANONICAL v1 (append-last) ===== */
@media (min-width: 861px) {
	body.has-catalog-tools .container,
	body.has-catalog-tools .site-content.container,
	body.has-catalog-tools .header-banner-row,
	body.has-catalog-tools .announcement-ticker.container,
	body.has-catalog-tools .catalog-search-sticky.container,
	body.has-catalog-tools .header-tools.container {
		width: min(1540px, 97vw) !important;
		max-width: none !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	body.has-catalog-tools .header-banner {
		padding: 8px 0 6px !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		display: flex !important;
		flex-wrap: wrap !important;
		justify-content: center !important;
		align-items: center !important;
		column-gap: 12px !important;
		row-gap: 10px !important;
		padding: 10px 18px 12px !important;
		border-radius: 20px !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		order: 1 !important;
		flex: 0 1 100% !important;
		width: min(640px, 44vw) !important;
		height: 104px !important;
		margin: 0 auto 2px !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		position: static !important;
		inset: auto !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 10px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-left {
		order: 2 !important;
	}

	body.has-catalog-tools #mainNav .nav-group.nav-right {
		order: 3 !important;
	}

	body.has-catalog-tools #mainNav .nav-group > a,
	body.has-catalog-tools #mainNav .nav-group .link-btn,
	body.has-catalog-tools #mainNav .cart-link,
	body.has-catalog-tools #mainNav .repair-link {
		min-width: 124px !important;
		height: 44px !important;
		min-height: 44px !important;
		padding: 0 14px !important;
		font-size: 0.92rem !important;
	}

	body.has-catalog-tools #mainNav .nav-right .cart-link {
		min-width: 132px !important;
	}

	body.has-catalog-tools #mainNav .nav-right .repair-link {
		min-width: 168px !important;
	}

	body.page-productos .catalog-grid-tools {
		width: 100% !important;
		padding: 8px 10px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-tools-inner {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) auto auto !important;
		align-items: center !important;
		gap: 10px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-count {
		justify-self: stretch !important;
	}

	body.page-productos #catalogGrid.product-grid,
	body.page-productos .product-grid {
		display: grid !important;
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: 14px !important;
		align-items: stretch !important;
		justify-items: stretch !important;
	}

	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card {
		width: 100% !important;
		max-width: none !important;
		margin: 0 !important;
	}
}

@media (min-width: 1200px) {
	body.page-productos #catalogGrid.product-grid,
	body.page-productos .product-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	}
}

@media (min-width: 1500px) {
	body.page-productos #catalogGrid.product-grid,
	body.page-productos .product-grid {
		grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
	}

	body.has-catalog-tools #mainNav .header-logo-link {
		width: min(700px, 42vw) !important;
		height: 112px !important;
	}
}

/* ===== PRODUCT DETAIL ACTIONS DESKTOP STACK (append-last) ===== */
@media (min-width: 861px) {
	body.page-producto .product-detail-actions,
	body[class*="page-producto-"] .product-detail-actions {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 10px !important;
		align-items: stretch !important;
	}

	body.page-producto .product-detail .add-cart-form,
	body[class*="page-producto-"] .product-detail .add-cart-form {
		grid-column: 1 !important;
		min-width: 0 !important;
		width: 100% !important;
	}

	body.page-producto .product-detail-actions .consult-stock-btn,
	body[class*="page-producto-"] .product-detail-actions .consult-stock-btn {
		grid-column: 1 !important;
		justify-self: start !important;
		width: auto !important;
		min-width: 230px !important;
		max-width: 100% !important;
	}
}

/* ===== PRODUCT DETAIL VISUAL UNIFICATION v1 (append-last) ===== */
@media (min-width: 861px) {
	body.page-producto .product-detail-actions,
	body[class*="page-producto-"] .product-detail-actions {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 10px !important;
		align-items: stretch !important;
		width: min(560px, 100%) !important;
	}

	body.page-producto .product-detail .add-cart-form,
	body[class*="page-producto-"] .product-detail .add-cart-form {
		display: grid !important;
		grid-template-columns: 86px minmax(0, 1fr) !important;
		gap: 10px !important;
		width: 100% !important;
		min-width: 0 !important;
		margin: 0 !important;
	}

	body.page-producto .product-detail .add-cart-form input[type="number"],
	body[class*="page-producto-"] .product-detail .add-cart-form input[type="number"],
	body.page-producto .product-detail .add-cart-form .detail-add-btn,
	body[class*="page-producto-"] .product-detail .add-cart-form .detail-add-btn,
	body.page-producto .product-detail-actions .consult-stock-btn,
	body[class*="page-producto-"] .product-detail-actions .consult-stock-btn {
		height: 42px !important;
		min-height: 42px !important;
	}

	body.page-producto .product-detail .add-cart-form .detail-add-btn,
	body[class*="page-producto-"] .product-detail .add-cart-form .detail-add-btn {
		width: 100% !important;
		justify-content: center !important;
	}

	body.page-producto .product-detail-actions .consult-stock-btn,
	body[class*="page-producto-"] .product-detail-actions .consult-stock-btn {
		grid-column: 1 !important;
		justify-self: stretch !important;
		width: 100% !important;
		min-width: 0 !important;
		max-width: none !important;
		justify-content: center !important;
	}

	body.page-producto .product-detail .price-group-detail,
	body[class*="page-producto-"] .product-detail .price-group-detail {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 6px !important;
		width: min(560px, 100%) !important;
		margin: 0 0 10px !important;
	}

	body.page-producto .product-detail .price.large,
	body.page-producto .product-detail .price-group-detail .price.price-offer,
	body[class*="page-producto-"] .product-detail .price.large,
	body[class*="page-producto-"] .product-detail .price-group-detail .price.price-offer {
		display: block !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 6px 10px !important;
		border: 1px solid var(--ui-price-border) !important;
		border-radius: 12px !important;
		background: transparent !important;
		color: var(--ui-price-text) !important;
		text-align: center !important;
		font-size: clamp(1.95rem, 2.25vw, 2.3rem) !important;
		font-weight: 900 !important;
		letter-spacing: 0.01em !important;
		line-height: 1.08 !important;
	}

	body.page-producto .product-detail .price-group-detail .price.price-original,
	body[class*="page-producto-"] .product-detail .price-group-detail .price.price-original {
		display: block !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
		background: transparent !important;
		border: 0 !important;
		text-align: center !important;
		color: #39558d !important;
		font-size: var(--ui-fs-400) !important;
		font-weight: 800 !important;
		text-decoration: line-through !important;
	}
}

/* ===== ADMIN PRODUCTOS MOBILE CARDS CANONICAL v1 (append-last) ===== */
@media (max-width: 980px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] {
		overflow: visible !important;
		border: 0 !important;
		background: transparent !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table {
		min-width: 0 !important;
		width: 100% !important;
		border-spacing: 0 10px !important;
		table-layout: fixed !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table colgroup,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table thead {
		display: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tbody {
		display: grid !important;
		gap: 10px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tr[data-admin-product-row] {
		display: grid !important;
		grid-template-columns: 84px minmax(0, 1fr) auto !important;
		grid-template-areas:
			"thumb id select"
			"thumb name name"
			"thumb category category"
			"price price price"
			"offer offer offer"
			"active active active"
			"actions actions actions" !important;
		column-gap: 10px !important;
		row-gap: 8px !important;
		padding: 10px !important;
		border: 1px solid #c6d9fb !important;
		border-radius: 12px !important;
		background: #f8fbff !important;
		position: relative !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 4px !important;
		border: 0 !important;
		padding: 0 !important;
		margin: 0 !important;
		min-width: 0 !important;
		overflow: visible !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td::before {
		content: attr(data-label) !important;
		display: block !important;
		font-size: 0.7rem !important;
		font-weight: 900 !important;
		letter-spacing: 0.04em !important;
		text-transform: uppercase !important;
		color: #2a56a7 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-thumb {
		grid-area: thumb !important;
		align-self: start !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-thumb::before {
		display: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-thumb .admin-product-thumb {
		width: 70px !important;
		height: 70px !important;
		max-width: 70px !important;
		max-height: 70px !important;
		object-fit: cover !important;
		border-radius: 10px !important;
		margin: 0 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-id {
		grid-area: id !important;
		justify-content: center !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-id::before {
		display: inline !important;
		margin-right: 6px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-id {
		flex-direction: row !important;
		align-items: center !important;
		gap: 6px !important;
		font-size: 1.05rem !important;
		font-weight: 800 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-select {
		grid-area: select !important;
		align-items: flex-end !important;
		justify-content: center !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-select::before {
		display: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-name {
		grid-area: name !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-category {
		grid-area: category !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-price {
		grid-area: price !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-offer {
		grid-area: offer !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-active {
		grid-area: active !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.admin-actions-cell {
		grid-area: actions !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-inline-field,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-picker,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-picker input,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-picker select {
		width: 100% !important;
		max-width: none !important;
		min-width: 0 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-price .admin-inline-field,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-offer .admin-inline-field {
		max-width: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-picker {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) 34px !important;
		align-items: center !important;
		gap: 6px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-reset {
		width: 34px !important;
		height: 34px !important;
		min-width: 34px !important;
		padding: 0 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-results {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
		z-index: 2 !important;
		margin-top: 6px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.admin-actions-cell::before {
		display: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell {
		display: grid !important;
		grid-template-columns: repeat(6, 34px) !important;
		grid-auto-rows: 34px !important;
		gap: 6px !important;
		align-items: center !important;
		justify-content: start !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .btn,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .icon-btn,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-save-btn {
		width: 34px !important;
		height: 34px !important;
		min-width: 34px !important;
		padding: 0 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .quick-edit-state {
		grid-column: 1 / -1 !important;
		min-height: 18px !important;
		font-size: 0.72rem !important;
	}
}

@media (max-width: 420px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table tr[data-admin-product-row] {
		grid-template-columns: 78px minmax(0, 1fr) auto !important;
		padding: 9px !important;
		column-gap: 8px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] td.cell-thumb .admin-product-thumb {
		width: 64px !important;
		height: 64px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell {
		grid-template-columns: repeat(5, 32px) !important;
		grid-auto-rows: 32px !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .btn,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .icon-btn,
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-save-btn {
		width: 32px !important;
		height: 32px !important;
		min-width: 32px !important;
	}
}

/* ===== ADMIN ACTIONS SINGLE ROW CANONICAL v1 (append-last) ===== */
body.page-admin-productos .admin-products-table .col-actions,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='wide'] .admin-products-table .col-actions,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='normal'] .admin-products-table .col-actions,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='compact'] .admin-products-table .col-actions {
	width: 320px !important;
}

body.page-admin-productos .admin-products-table td.admin-actions-cell::before,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-products-table td.admin-actions-cell::before {
	display: none !important;
	content: none !important;
}

body.page-admin-productos .admin-actions-cell,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 8px !important;
	flex-wrap: nowrap !important;
	white-space: nowrap !important;
	min-width: 0 !important;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-actions-icons {
	display: inline-flex !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 6px !important;
	flex: 0 0 auto !important;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons .inline-form,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-actions-icons .inline-form {
	display: inline-flex !important;
	margin: 0 !important;
	flex: 0 0 auto !important;
}

body.page-admin-productos .admin-actions-cell .admin-actions-icons .btn,
body.page-admin-productos .admin-actions-cell .admin-actions-icons .icon-btn,
body.page-admin-productos .admin-actions-cell .admin-actions-icons .admin-save-btn,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-actions-icons .btn,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-actions-icons .icon-btn,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .admin-actions-icons .admin-save-btn {
	width: 32px !important;
	height: 32px !important;
	min-width: 32px !important;
	padding: 0 !important;
}

body.page-admin-productos .admin-actions-cell .quick-edit-state,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .quick-edit-state {
	display: inline-flex !important;
	align-items: center !important;
	flex: 0 0 auto !important;
	margin: 0 0 0 4px !important;
	min-height: 0 !important;
	line-height: 1 !important;
	white-space: nowrap !important;
	font-size: 0.72rem !important;
}

body.page-admin-productos .admin-actions-cell .quick-edit-state:empty,
body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell .quick-edit-state:empty {
	display: none !important;
}

@media (max-width: 980px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-actions-cell {
		overflow-x: auto !important;
		overflow-y: hidden !important;
		padding-bottom: 2px !important;
	}
}

/* ===== HEADER CTA BUTTON BACKGROUND v2 (append-last) ===== */
body.has-catalog-tools #mainNav .cart-link {
	background: linear-gradient(180deg, #8a35ff 0%, #5e22c7 100%) !important;
	border: 1px solid rgba(201, 160, 255, 0.62) !important;
	color: #f7f1ff !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
}

body.has-catalog-tools #mainNav .cart-link:hover {
	filter: brightness(1.08) !important;
}

body.has-catalog-tools #mainNav .cart-link.is-active {
	background: linear-gradient(180deg, #9446ff 0%, #6629cf 100%) !important;
	border-color: rgba(214, 184, 255, 0.72) !important;
	color: #ffffff !important;
}

body.has-catalog-tools #mainNav .repair-link {
	background: linear-gradient(180deg, #43c6ff 0%, #1797df 100%) !important;
	border: 1px solid rgba(178, 236, 255, 0.72) !important;
	color: #eefdff !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
}

body.has-catalog-tools #mainNav .repair-link:hover {
	filter: brightness(1.08) !important;
}

body.has-catalog-tools #mainNav .repair-link.is-active {
	background: linear-gradient(180deg, #55d0ff 0%, #1fa2e7 100%) !important;
	border-color: rgba(205, 245, 255, 0.78) !important;
	color: #ffffff !important;
}

/* ===== HEADER CTA BUTTON BACKGROUND v3 DESKTOP FORCE ===== */
.site-header #mainNav a.cart-link,
.site-header #mainNav a.cart-link:link,
.site-header #mainNav a.cart-link:visited {
	background: linear-gradient(180deg, #8a35ff 0%, #5e22c7 100%) !important;
	border: 1px solid rgba(201, 160, 255, 0.62) !important;
	color: #f7f1ff !important;
}

.site-header #mainNav a.repair-link,
.site-header #mainNav a.repair-link:link,
.site-header #mainNav a.repair-link:visited {
	background: linear-gradient(180deg, #43c6ff 0%, #1797df 100%) !important;
	border: 1px solid rgba(178, 236, 255, 0.72) !important;
	color: #eefdff !important;
}

.site-header #mainNav a.cart-link:hover,
.site-header #mainNav a.repair-link:hover {
	filter: brightness(1.08) !important;
}

/* ===== MOBILE NAV TOGGLE CHEVRON v1 (append-last) ===== */
@media (max-width: 980px) {
	body.has-catalog-tools #mainNav .nav-toggle {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 8px !important;
	}

	body.has-catalog-tools #mainNav .nav-toggle::after {
		content: "▾";
		display: inline-block;
		font-size: 0.95em;
		line-height: 1;
		font-weight: 900;
		color: #ffffff;
		transform: translateY(-1px) rotate(0deg);
		transition: transform 180ms ease, opacity 180ms ease;
		opacity: 0.95;
	}

	body.has-catalog-tools #mainNav .nav-toggle[aria-expanded='true']::after {
		transform: translateY(-1px) rotate(180deg);
	}
}

/* ===== CART COLOR UNIFICATION TURQUESA v2 (append-last) ===== */
:root {
	--cart-unified-top: #22b8cf;
	--cart-unified-bottom: #138fa8;
	--cart-unified-border: #8be0ef;
	--cart-unified-text: #ecfcff;
	--cart-unified-soft-bg: #d9f7fb;
	--cart-unified-soft-border: #85d5e5;
	--cart-unified-soft-text: #0d5360;
}

/* Header carrito (desktop + mobile) */
body.has-catalog-tools #mainNav .cart-link,
body.has-catalog-tools #mainNav .cart-link.is-active,
.site-header #mainNav a.cart-link,
.site-header #mainNav a.cart-link:link,
.site-header #mainNav a.cart-link:visited {
	background: linear-gradient(180deg, var(--cart-unified-top) 0%, var(--cart-unified-bottom) 100%) !important;
	border: 1px solid var(--cart-unified-border) !important;
	color: var(--cart-unified-text) !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 0 1px rgba(76, 201, 255, 0.2) !important;
}

body.has-catalog-tools #mainNav .cart-link:hover,
.site-header #mainNav a.cart-link:hover {
	filter: brightness(1.08) !important;
}

body.has-catalog-tools #mainNav .cart-link .nav-cart-icon,
body.has-catalog-tools #mainNav .cart-link .cart-icon-svg,
.site-header #mainNav a.cart-link .nav-cart-icon,
.site-header #mainNav a.cart-link .cart-icon-svg {
	color: #ffffff !important;
}

body.has-catalog-tools #mainNav .cart-pill,
.site-header #mainNav a.cart-link .cart-pill {
	background: #ebfcff !important;
	color: #0d5360 !important;
	border: 1px solid #9be1ee !important;
}

/* Boton carrito en barra sticky de mobile */
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile,
.catalog-search-sticky .search-cart-mobile {
	background: linear-gradient(180deg, var(--cart-unified-top) 0%, var(--cart-unified-bottom) 100%) !important;
	border: 1px solid var(--cart-unified-border) !important;
	color: var(--cart-unified-text) !important;
}

.catalog-search-sticky .search-cart-mobile .btn-icon,
.catalog-search-sticky .search-cart-mobile .cart-icon-badge {
	color: #ffffff !important;
}

.catalog-search-sticky .search-cart-mobile-count {
	background: #e9fcff !important;
	color: #0d5360 !important;
	border: 1px solid #99dfee !important;
}

/* Badges y marca de carrito en cards */
#catalogGrid .in-cart-badge,
.product-grid .in-cart-badge,
.in-cart-badge {
	background: linear-gradient(180deg, #e8fbff 0%, var(--cart-unified-soft-bg) 100%) !important;
	border: 1px solid var(--cart-unified-soft-border) !important;
	color: var(--cart-unified-soft-text) !important;
}

#catalogGrid .in-cart-badge strong,
.product-grid .in-cart-badge strong,
.in-cart-badge strong {
	color: #0c4f5d !important;
}

#catalogGrid .card-cart-mark,
.product-grid .card-cart-mark,
.card-cart-mark {
	border-color: #8fd9e8 !important;
	background: linear-gradient(180deg, #ecfcff 0%, #d9f7fb 100%) !important;
	color: #0f5c6d !important;
}

#catalogGrid .card-cart-mark .cart-icon-badge,
.product-grid .card-cart-mark .cart-icon-badge,
.card-cart-mark .cart-icon-badge {
	color: #0f5c6d !important;
}

#catalogGrid .product-card.in-cart,
.product-grid .product-card.in-cart,
.product-card.in-cart {
	border-color: #79cadb !important;
	box-shadow: 0 0 0 1px rgba(112, 207, 223, 0.28), 0 10px 24px rgba(8, 51, 59, 0.26) !important;
}

/* Resumen/total en carrito */
body.page-carrito .cart-head-total {
	background: linear-gradient(180deg, #e9fcff 0%, #d7f5fa 100%) !important;
	border: 1px solid #8fd9e8 !important;
	color: #0d5360 !important;
}

/* ===== CART COLOR MATCH HEADER v4 (append-last) ===== */
:root {
	--cart-u-top: #1b4698;
	--cart-u-bottom: #173f88;
	--cart-u-border: #5d86d7;
	--cart-u-text: #f3f7ff;
	--cart-u-icon-bg: #f2f6ff;
	--cart-u-icon-text: #1e4ea4;
	--cart-u-soft-bg: #e6efff;
	--cart-u-soft-border: #a6bbe9;
	--cart-u-soft-text: #1e4ea4;
}

/* Botones/acciones de carrito con color uniforme */
body.has-catalog-tools #mainNav .cart-link,
body.has-catalog-tools #mainNav .cart-link.is-active,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile,
body.page-home .add-cart-btn,
body.page-productos .add-cart-btn,
body.page-producto .detail-add-btn,
body.page-carrito .cart-item .btn.btn-soft {
	background: linear-gradient(180deg, var(--cart-u-top) 0%, var(--cart-u-bottom) 100%) !important;
	border: 1px solid var(--cart-u-border) !important;
	color: var(--cart-u-text) !important;
}

/* Iconos de carrito visibles y consistentes */
body.has-catalog-tools #mainNav .cart-link .cart-icon-badge,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile .cart-icon-badge,
body.page-home .add-cart-btn .cart-icon-badge,
body.page-productos .add-cart-btn .cart-icon-badge,
body.page-producto .detail-add-icon.cart-icon-badge,
#catalogGrid .card-cart-mark .cart-icon-badge,
.product-grid .card-cart-mark .cart-icon-badge {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 18px !important;
	height: 18px !important;
	flex: 0 0 18px !important;
	background: var(--cart-u-icon-bg) !important;
	color: var(--cart-u-icon-text) !important;
	border: 1px solid #a6bbe9 !important;
	border-radius: 999px !important;
	box-shadow: none !important;
}

body.has-catalog-tools #mainNav .cart-link .cart-icon-svg,
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile .cart-icon-svg,
body.page-home .add-cart-btn .cart-icon-svg,
body.page-productos .add-cart-btn .cart-icon-svg,
body.page-producto .detail-add-icon .cart-icon-svg,
#catalogGrid .card-cart-mark .cart-icon-svg,
.product-grid .card-cart-mark .cart-icon-svg {
	width: 11px !important;
	height: 11px !important;
	display: block !important;
	color: currentColor !important;
}

/* Boton carrito mobile: asegurar visibilidad del icono y contador */
body.has-catalog-tools .catalog-search-sticky .search-cart-mobile .btn-icon,
.catalog-search-sticky .search-cart-mobile .btn-icon {
	opacity: 1 !important;
	visibility: visible !important;
}

body.has-catalog-tools .catalog-search-sticky .search-cart-mobile-count,
.catalog-search-sticky .search-cart-mobile-count {
	background: #f2f6ff !important;
	color: #1e4ea4 !important;
	border: 1px solid #a6bbe9 !important;
}

/* Marca carrito en card */
#catalogGrid .card-cart-mark,
.product-grid .card-cart-mark,
.card-cart-mark {
	background: linear-gradient(180deg, var(--cart-u-top) 0%, var(--cart-u-bottom) 100%) !important;
	border: 1px solid var(--cart-u-border) !important;
	color: var(--cart-u-text) !important;
}

/* Badge en carrito + total */
#catalogGrid .in-cart-badge,
.product-grid .in-cart-badge,
.in-cart-badge {
	background: linear-gradient(180deg, #f2f6ff 0%, var(--cart-u-soft-bg) 100%) !important;
	border: 1px solid var(--cart-u-soft-border) !important;
	color: var(--cart-u-soft-text) !important;
}

#catalogGrid .in-cart-badge strong,
.product-grid .in-cart-badge strong,
.in-cart-badge strong {
	color: #1b448f !important;
}

body.page-carrito .cart-head-total {
	background: linear-gradient(180deg, #f2f6ff 0%, #e5efff 100%) !important;
	border: 1px solid var(--cart-u-soft-border) !important;
	color: #1e4ea4 !important;
}

/* ===== PRODUCT LINK BACKGROUND WHITE v1 (append-last) ===== */
a.product,
a.product:link,
a.product:visited,
a.product-image,
a.product-image:link,
a.product-image:visited,
body.page-home .product-grid .product-image,
body.page-productos #catalogGrid .product-image,
body.page-productos .product-grid .product-image {
	background: #ffffff !important;
}

/* ===== PRODUCT TYPOGRAPHY DM SANS + ARCHIVO v3 (append-last) ===== */
:root {
	--font-product-text: 'DM Sans', 'Nunito Sans', sans-serif;
	--font-product-price: 'Archivo', 'Montserrat', sans-serif;
}

/* Textos de producto */
body.page-home .product-grid .product-category,
body.page-home .product-grid .product-body h3,
body.page-home .product-grid .product-body h3 a,
body.page-productos #catalogGrid .product-category,
body.page-productos #catalogGrid .product-body h3,
body.page-productos #catalogGrid .product-body h3 a,
body.page-productos .product-grid .product-category,
body.page-productos .product-grid .product-body h3,
body.page-productos .product-grid .product-body h3 a,
body.page-producto .product-detail h1,
body.page-producto .product-detail .product-description,
body.page-carrito .cart-item-info h3 {
	font-family: var(--font-product-text) !important;
}

/* Precios */
body.page-home .product-grid .price,
body.page-productos #catalogGrid .price,
body.page-productos .product-grid .price,
body.page-producto .product-detail .price.large,
body.page-producto .product-detail .price-group-detail .price,
body.page-carrito .cart-item-price,
body.page-carrito .cart-item-total,
body.page-carrito .cart-head-total {
	font-family: var(--font-product-price) !important;
	letter-spacing: 0.01em !important;
}

/* Precio original (tachado) un poco mas liviano */
body.page-home .product-grid .price.price-original,
body.page-productos #catalogGrid .price.price-original,
body.page-productos .product-grid .price.price-original,
body.page-producto .product-detail .price-group-detail .price.price-original {
	font-family: var(--font-product-price) !important;
	font-weight: 600 !important;
}

/* ===== PRODUCT DETAIL TYPOGRAPHY FORCE v4 (append-last) ===== */
body.page-producto .product-detail h1,
body[class*="page-producto-"] .product-detail h1,
body.page-producto .product-detail .product-description,
body[class*="page-producto-"] .product-detail .product-description,
body.page-producto .product-detail .product-meta p,
body[class*="page-producto-"] .product-detail .product-meta p,
body.page-producto .product-detail .product-category,
body[class*="page-producto-"] .product-detail .product-category {
	font-family: var(--font-product-text) !important;
}

body.page-producto .product-detail .price.large,
body[class*="page-producto-"] .product-detail .price.large,
body.page-producto .product-detail .price-group-detail .price,
body[class*="page-producto-"] .product-detail .price-group-detail .price {
	font-family: var(--font-product-price) !important;
	letter-spacing: 0.01em !important;
}

body.page-producto .product-detail .price-group-detail .price.price-original,
body[class*="page-producto-"] .product-detail .price-group-detail .price.price-original {
	font-family: var(--font-product-price) !important;
	font-weight: 600 !important;
}

/* ===== PRODUCT DETAIL RELATED CAROUSEL v1 (append-last) ===== */
.product-related {
	margin-top: 14px;
	padding: 12px;
}

.related-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
}

.related-head h2 {
	margin: 0;
	font-size: clamp(1rem, 1.8vw, 1.2rem);
	font-weight: 800;
}

.related-nav {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.related-nav-btn {
	width: 42px;
	height: 42px;
	border-radius: 12px;
	border: 1px solid #a9c2ef;
	background: linear-gradient(180deg, #316bd8 0%, #2456b4 100%);
	color: #f3f8ff;
	font-size: 1.35rem;
	line-height: 1;
	font-weight: 800;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 16px rgba(20, 49, 107, 0.28);
}

.related-nav-btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
}

.related-track-wrap {
	overflow: hidden;
}

.related-track {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(200px, 1fr);
	gap: 10px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
	scrollbar-color: #739ae2 transparent;
	padding-bottom: 2px;
}

.related-track::-webkit-scrollbar {
	height: 8px;
}

.related-track::-webkit-scrollbar-thumb {
	background: #739ae2;
	border-radius: 999px;
}

.related-item {
	scroll-snap-align: start;
	border: 1px solid #bbcdf0;
	border-radius: 14px;
	background: #f8fbff;
	overflow: hidden;
	display: grid;
	grid-template-rows: auto 1fr;
	min-height: 100%;
}

.related-image {
	display: block;
	background: #ffffff;
	border-bottom: 1px solid #d5e2fa;
	aspect-ratio: 4 / 3;
}

.related-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.related-body {
	padding: 10px;
	display: grid;
	align-content: start;
	gap: 6px;
}

.related-category {
	margin: 0;
	font-size: 0.74rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: #2d57af;
}

.related-body h3 {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.3;
	font-weight: 800;
}

.related-body h3 a {
	text-decoration: none;
	color: inherit;
}

.related-prices {
	display: grid;
	gap: 2px;
}

.related-prices .price {
	margin: 0;
}

.related-view-btn {
	margin-top: 4px;
	width: 100%;
}

@media (max-width: 860px) {
	.product-related {
		padding: 10px;
	}

	.related-head {
		align-items: center;
	}

	.related-head h2 {
		font-size: 1rem;
	}

	.related-nav-btn {
		width: 48px;
		height: 48px;
		border-radius: 13px;
		font-size: 1.5rem;
		font-weight: 900;
	}

	.related-track {
		grid-auto-columns: 100%;
		gap: 8px;
		scroll-padding-inline: 0;
	}

	.related-item {
		width: 100%;
	}
}

/* ===== PRODUCT DETAIL DESCRIPTION TOGGLE (append-last) ===== */
body.page-producto .product-detail .product-description-short,
body[class*='page-producto-'] .product-detail .product-description-short {
	margin: 0;
}

body.page-producto .product-detail .product-description-toggle,
body[class*='page-producto-'] .product-detail .product-description-toggle {
	margin-top: 10px;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: #ffffff;
	overflow: hidden;
}

body.page-producto .product-detail .product-description-toggle > summary,
body[class*='page-producto-'] .product-detail .product-description-toggle > summary {
	list-style: none;
	cursor: pointer;
	padding: 10px 12px;
	font-size: 0.84rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #17408f;
	background: linear-gradient(180deg, #eff5ff 0%, #e6efff 100%);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}

body.page-producto .product-detail .product-description-toggle > summary::after,
body[class*='page-producto-'] .product-detail .product-description-toggle > summary::after {
	content: '+';
	font-size: 1rem;
	font-weight: 900;
	line-height: 1;
	color: #15418e;
}

body.page-producto .product-detail .product-description-toggle[open] > summary::after,
body[class*='page-producto-'] .product-detail .product-description-toggle[open] > summary::after {
	content: '-';
}

body.page-producto .product-detail .product-description-toggle > summary::-webkit-details-marker,
body[class*='page-producto-'] .product-detail .product-description-toggle > summary::-webkit-details-marker {
	display: none;
}

body.page-producto .product-detail .product-description-full,
body[class*='page-producto-'] .product-detail .product-description-full {
	border-top: 1px solid var(--border);
	padding: 11px 12px;
	white-space: normal;
}

/* ===== ADMIN CATEGORY DROPDOWN OVER TABLE (append-last) ===== */
body.page-admin-productos .filter-panel.admin-products-panel,
body.page-admin-productos .admin-products-filters,
body.page-admin-productos .admin-products-filters .category-block,
body.page-admin-productos .admin-category-autocomplete {
	position: relative !important;
	overflow: visible !important;
}

body.page-admin-productos .filter-panel.admin-products-panel {
	z-index: 120 !important;
}

body.page-admin-productos .admin-products-filters {
	z-index: 121 !important;
}

body.page-admin-productos .admin-products-filters .category-block {
	z-index: 122 !important;
}

body.page-admin-productos .admin-category-autocomplete {
	z-index: 123 !important;
}

body.page-admin-productos .admin-category-results {
	position: absolute !important;
	z-index: 9999 !important;
}

body.page-admin-productos .admin-products-grid-card,
body.page-admin-productos .admin-products-table-wrap {
	position: relative;
	z-index: 1;
}

/* ===== ADMIN FILTERS WITHOUT STATUS SELECT (append-last) ===== */
body.page-admin-productos .admin-products-filters {
	grid-template-columns: minmax(280px, 1.9fr) minmax(230px, 1.2fr) auto !important;
	align-items: end !important;
}

body.page-admin-productos .admin-products-filters .search-block,
body.page-admin-productos .admin-products-filters .category-block,
body.page-admin-productos .admin-products-filters .filter-actions {
	min-width: 0;
}

@media (max-width: 1180px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	body.page-admin-productos .admin-products-filters .search-block,
	body.page-admin-productos .admin-products-filters .filter-actions {
		grid-column: 1 / -1;
	}
}

@media (max-width: 860px) {
	body.page-admin-productos .admin-products-filters {
		grid-template-columns: minmax(0, 1fr) !important;
	}
}

/* ===== ADMIN FILTER VISIBILITY FIX (final-override) ===== */
body.page-admin-productos #adminProductsTable tr[data-admin-product-row].is-hidden,
body.page-admin-productos #adminProductsTable tr[data-admin-no-results-row].is-hidden {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

@media (max-width: 980px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] #adminProductsTable tr[data-admin-product-row]:not(.is-hidden) {
		display: grid !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] #adminProductsTable tr[data-admin-no-results-row]:not(.is-hidden) {
		display: block !important;
	}
}

/* ===== ADMIN CATEGORY PICKER VIEWPORT FIT (final-override) ===== */
body.page-admin-productos .admin-products-table-wrap {
	overflow-y: visible !important;
}

body.page-admin-productos .admin-row-category-picker {
	position: relative !important;
	z-index: 4;
}

body.page-admin-productos .admin-row-category-picker.is-results-open {
	z-index: 1200 !important;
}

body.page-admin-productos .admin-row-category-results {
	top: calc(100% + 4px) !important;
	bottom: auto !important;
}

body.page-admin-productos .admin-row-category-results.is-open-up {
	top: auto !important;
	bottom: calc(100% + 4px) !important;
}

body.page-admin-productos .admin-row-category-results.is-open-down {
	top: calc(100% + 4px) !important;
	bottom: auto !important;
}

@media (max-width: 980px) {
	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-results {
		position: absolute !important;
		left: 0 !important;
		right: 0 !important;
		top: calc(100% + 6px) !important;
		bottom: auto !important;
		margin-top: 0 !important;
		z-index: 2200 !important;
	}

	body.page-admin-productos .admin-products-table-wrap[data-admin-grid-mode='cards'] .admin-row-category-results.is-open-up {
		top: auto !important;
		bottom: calc(100% + 6px) !important;
	}
}

/* ===== CATALOG SIDEBAR HIERARCHY (desktop) ===== */
body.page-productos .catalog-layout {
	display: grid;
	grid-template-columns: clamp(230px, 21vw, 285px) minmax(0, 1fr);
	gap: 14px;
	align-items: start;
}

body.page-productos .catalog-layout-main {
	min-width: 0;
}

body.page-productos .catalog-sidebar {
	position: sticky;
	top: 14px;
	padding: 12px;
	border-radius: 18px;
	border: 1px solid #2b5cbe;
	background: linear-gradient(180deg, #173f92 0%, #11347a 100%);
	box-shadow: 0 14px 28px rgba(8, 28, 71, 0.24);
	color: #eef4ff;
}

body.page-productos .catalog-sidebar-header {
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(173, 197, 255, 0.35);
	margin-bottom: 10px;
}

body.page-productos .catalog-sidebar-header h3 {
	margin: 0;
	font-size: 0.95rem;
	font-weight: 900;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

body.page-productos .catalog-sidebar-header p {
	margin: 3px 0 0;
	font-size: 0.74rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #d5e4ff;
}

body.page-productos .catalog-sidebar-all-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(151, 186, 255, 0.6);
	background: rgba(255, 255, 255, 0.09);
	color: #eff5ff;
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.18s ease, transform 0.18s ease, border-color 0.18s ease;
}

body.page-productos .catalog-sidebar-all-btn:hover {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.16);
}

body.page-productos .catalog-sidebar-all-btn.is-active {
	background: linear-gradient(180deg, #7ad8ff 0%, #39a9ef 100%);
	border-color: #a7e6ff;
	color: #083d74;
}

body.page-productos .catalog-sidebar-groups {
	margin-top: 10px;
	display: grid;
	gap: 8px;
}

body.page-productos .catalog-sidebar-group {
	border: 1px solid rgba(157, 187, 247, 0.48);
	border-radius: 12px;
	background: rgba(8, 24, 61, 0.2);
	overflow: hidden;
}

body.page-productos .catalog-sidebar-group > summary {
	list-style: none;
	padding: 9px 11px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	cursor: pointer;
	font-size: 0.79rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #f2f7ff;
}

body.page-productos .catalog-sidebar-group > summary::-webkit-details-marker {
	display: none;
}

body.page-productos .catalog-sidebar-group > summary::after {
	content: '';
	flex: 0 0 auto;
	width: 8px;
	height: 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	opacity: 0.85;
	margin-left: 2px;
	transition: transform 0.2s ease;
}

body.page-productos .catalog-sidebar-group[open] > summary::after {
	transform: rotate(-135deg) translateY(-2px);
}

body.page-productos .catalog-sidebar-group > summary > small {
	margin-left: auto;
	padding: 2px 7px;
	border-radius: 999px;
	border: 1px solid rgba(166, 197, 255, 0.75);
	background: rgba(240, 247, 255, 0.18);
	color: #ffffff;
	font-size: 0.7rem;
	font-weight: 800;
	letter-spacing: 0;
}

body.page-productos .catalog-sidebar-subcategories {
	padding: 4px 8px 8px;
	display: grid;
	gap: 5px;
}

body.page-productos .catalog-sidebar-category-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 10px;
	border: 1px solid rgba(147, 182, 248, 0.5);
	background: rgba(255, 255, 255, 0.08);
	color: #ecf3ff;
	cursor: pointer;
	font-size: 0.76rem;
	font-weight: 700;
	line-height: 1.2;
	text-align: left;
}

body.page-productos .catalog-sidebar-category-btn small {
	font-size: 0.69rem;
	font-weight: 700;
	color: #d8e6ff;
	opacity: 0.95;
}

body.page-productos .catalog-sidebar-category-btn:hover {
	background: rgba(255, 255, 255, 0.16);
	border-color: rgba(173, 203, 255, 0.85);
}

body.page-productos .catalog-sidebar-category-btn.is-active {
	background: linear-gradient(180deg, #7ad8ff 0%, #39a9ef 100%);
	border-color: #a7e6ff;
	color: #083d74;
}

body.page-productos .catalog-sidebar-category-btn.is-active small {
	color: #0f4f8f;
}

@media (max-width: 1080px) {
	body.page-productos .catalog-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	body.page-productos .catalog-sidebar {
		display: none;
	}
}

/* ===== PRODUCTOS MOBILE: GRUPO + SUBCATEGORIA ===== */
body.page-productos .header-tools .category-mobile-picker {
	display: none;
}

body.page-productos .header-tools .category-select-full-wrap {
	display: block;
}

@media (max-width: 860px) {
	body.page-productos .header-tools .category-mobile-picker {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: 8px;
		align-items: end;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field {
		display: grid;
		gap: 4px;
		min-width: 0;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field label {
		margin: 0;
		font-size: 0.62rem;
		font-weight: 800;
		letter-spacing: 0.05em;
		text-transform: uppercase;
		color: rgba(227, 238, 255, 0.96);
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field select {
		width: 100%;
		height: 42px;
		padding: 9px 11px;
		border-radius: 12px;
		border: 1px solid #9dbef7;
		background: #eef4ff;
		color: #17366f;
		font-size: 0.93rem;
		font-weight: 700;
		line-height: 1.2;
	}

	body.page-productos .header-tools .category-select-full-wrap {
		display: none;
	}
}

@media (max-width: 420px) {
	body.page-productos .header-tools .category-mobile-picker {
		grid-template-columns: minmax(0, 1fr);
		gap: 6px;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field select {
		height: 40px;
		font-size: 0.89rem;
	}
}

/* ===== PREMIUM POLISH + WIDE DESKTOP CANONICAL v2 (append-last) ===== */
@media (min-width: 861px) {
	:root {
		--container: min(1840px, 98.8vw);
	}

	body {
		overflow-x: hidden;
	}

	.container,
	.site-content.container,
	.catalog-head.container,
	.catalog-search-sticky.container,
	.filter-panel.card-surface.header-tools.container,
	.announcement-ticker.container,
	.footer-legacy-grid.container,
	.footer-copy.container {
		width: min(1840px, 98.8vw) !important;
		max-width: none !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	body.page-admin-productos .site-content.container,
	body.page-admin .site-content.container {
		width: min(1900px, 99vw) !important;
		max-width: none !important;
	}

	body.page-productos .catalog-layout {
		grid-template-columns: clamp(238px, 18vw, 300px) minmax(0, 1fr) !important;
		gap: 16px !important;
		align-items: start !important;
	}

	body.page-productos .catalog-layout-main {
		min-width: 0 !important;
	}

	body.page-productos #catalogGrid.product-grid,
	body.page-productos .product-grid,
	body.page-home .product-grid {
		grid-template-columns: repeat(auto-fill, minmax(236px, 1fr)) !important;
		gap: 14px !important;
		align-items: stretch !important;
	}

	body.page-productos #catalogGrid .product-card,
	body.page-productos .product-grid .product-card,
	body.page-home .product-grid .product-card {
		width: 100% !important;
		max-width: none !important;
		height: 100% !important;
		display: flex !important;
		flex-direction: column !important;
	}

	body.page-productos #catalogGrid .product-body,
	body.page-productos .product-grid .product-body,
	body.page-home .product-grid .product-body {
		display: flex !important;
		flex-direction: column !important;
		flex: 1 1 auto !important;
	}

	body.page-productos #catalogGrid .product-meta-grid,
	body.page-productos .product-grid .product-meta-grid,
	body.page-home .product-grid .product-meta-grid {
		margin-top: auto !important;
	}

	body.page-carrito .cart-layout {
		grid-template-columns: minmax(0, 1fr) minmax(300px, 380px) !important;
		gap: 16px !important;
		align-items: start !important;
	}

	body[class*='page-producto-'] .product-view,
	body.page-producto .product-view {
		grid-template-columns: minmax(340px, 0.92fr) minmax(420px, 1.08fr) !important;
		gap: 16px !important;
		align-items: start !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		row-gap: 10px !important;
	}

	body.has-catalog-tools #mainNav .nav-group {
		flex-wrap: wrap !important;
		row-gap: 8px !important;
	}

	body.page-admin-productos .admin-products-grid-card,
	body.page-admin-productos .admin-products-table-wrap {
		width: 100% !important;
		max-width: none !important;
	}

	body.page-admin-productos .admin-products-table-wrap {
		overflow-x: auto !important;
		overflow-y: visible !important;
		padding-bottom: 8px !important;
	}

	.card-surface,
	.card {
		border: 1px solid rgba(23, 62, 147, 0.18) !important;
		box-shadow: 0 14px 30px rgba(15, 38, 79, 0.11), 0 1px 0 rgba(255, 255, 255, 0.75) inset !important;
	}

	.product-card.card-surface,
	.category-tile.card-surface,
	.related-item,
	.cart-item,
	.cart-summary,
	.catalog-sidebar,
	.catalog-grid-tools,
	.filter-panel.card-surface.header-tools,
	.catalog-search-sticky,
	.announcement-ticker,
	.product-detail.card-surface,
	.product-media.card-surface {
		border: 1px solid rgba(27, 76, 160, 0.22) !important;
		box-shadow: 0 16px 32px rgba(10, 34, 76, 0.13), 0 1px 0 rgba(255, 255, 255, 0.75) inset !important;
	}

	.product-card.card-surface:hover,
	.category-tile.card-surface:hover,
	.related-item:hover {
		box-shadow: 0 22px 40px rgba(9, 31, 72, 0.18), 0 1px 0 rgba(255, 255, 255, 0.8) inset !important;
	}

	.btn,
	button,
	input[type='text'],
	input[type='search'],
	input[type='number'],
	input[type='email'],
	input[type='password'],
	select,
	textarea {
		border-radius: 12px !important;
	}

	input[type='text'],
	input[type='search'],
	input[type='number'],
	input[type='email'],
	input[type='password'],
	select,
	textarea {
		border: 1px solid rgba(41, 83, 163, 0.28) !important;
		box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset !important;
		background-clip: padding-box !important;
	}

	.btn,
	.main-nav .nav-group > a,
	.main-nav .nav-group .link-btn,
	.main-nav .nav-group .categories-menu summary {
		border-width: 1px !important;
		box-shadow: 0 10px 18px rgba(11, 38, 85, 0.2) !important;
	}

	.btn:focus-visible,
	button:focus-visible,
	a:focus-visible,
	input:focus-visible,
	select:focus-visible,
	textarea:focus-visible {
		outline: 2px solid rgba(32, 113, 245, 0.38) !important;
		outline-offset: 2px !important;
	}

	.catalog-sidebar::-webkit-scrollbar,
	.categories-dropdown::-webkit-scrollbar {
		width: 10px;
	}

	.catalog-sidebar::-webkit-scrollbar-thumb,
	.categories-dropdown::-webkit-scrollbar-thumb {
		border-radius: 999px;
		border: 2px solid transparent;
		background-clip: padding-box;
		background-color: rgba(157, 184, 238, 0.65);
	}
}

/* ===== FILTER BAR CATEGORY PARENT/CHILD v3 (append-last) ===== */
body.page-productos .catalog-layout {
	grid-template-columns: minmax(0, 1fr) !important;
}

body.page-productos .catalog-sidebar {
	display: none !important;
}

body.page-productos .header-tools .category-mobile-picker {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
	gap: 8px !important;
	align-items: end !important;
}

body.page-productos .header-tools .category-select-full-wrap {
	display: none !important;
}

body.page-productos .header-tools .category-mobile-picker .mobile-category-field[data-category-sub-field].is-collapsed {
	display: none !important;
}

body.page-productos .header-tools .category-mobile-picker .mobile-category-field select:disabled {
	opacity: 0.68;
	cursor: not-allowed;
}

@media (min-width: 861px) {
	body.page-productos .header-tools .category-mobile-picker {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
		gap: 10px !important;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field label {
		font-size: 0.68rem !important;
		font-weight: 800 !important;
		letter-spacing: 0.05em !important;
		text-transform: uppercase !important;
	}
}

@media (max-width: 860px) {
	body.page-productos .header-tools .category-mobile-picker {
		grid-template-columns: minmax(0, 1fr) !important;
	}
}

/* ===== DESKTOP WIDTH BALANCE v4 (append-last) ===== */
@media (min-width: 861px) {
	:root {
		--desktop-master-width: min(1680px, 96.5vw);
	}

	body.has-catalog-tools .header-banner-row,
	body.has-catalog-tools .announcement-ticker.container,
	body.has-catalog-tools .catalog-search-sticky.container,
	body.has-catalog-tools .filter-panel.card-surface.header-tools.container,
	body.has-catalog-tools .site-content.container,
	body.has-catalog-tools .footer-legacy-grid.container,
	body.has-catalog-tools .footer-copy.container {
		width: var(--desktop-master-width) !important;
		max-width: none !important;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	body.has-catalog-tools #mainNav.main-nav {
		width: 100% !important;
	}

	body.page-productos .header-tools .header-catalog-filters,
	body.page-productos .header-tools .catalog-filters {
		display: grid !important;
		grid-template-columns: minmax(0, 1.45fr) 1px minmax(500px, 1fr) !important;
		gap: 10px 14px !important;
		align-items: end !important;
	}

	body.page-productos .header-tools .search-block,
	body.page-productos .header-tools .category-block {
		min-width: 0 !important;
	}

	body.page-productos .header-tools .search-inline {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) auto !important;
		gap: 10px !important;
		align-items: center !important;
		width: 100% !important;
	}

	body.page-productos .header-tools .search-inline input[type='text'],
	body.page-productos .header-tools .search-inline input[type='search'] {
		min-width: 0 !important;
		width: 100% !important;
	}

	body.page-productos .header-tools .category-mobile-picker {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
		gap: 10px !important;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field {
		min-width: 0 !important;
	}

	body.page-productos .header-tools .category-mobile-picker .mobile-category-field select {
		width: 100% !important;
	}
}

@media (min-width: 861px) and (max-width: 1280px) {
	body.page-productos .header-tools .header-catalog-filters,
	body.page-productos .header-tools .catalog-filters {
		grid-template-columns: minmax(0, 1fr) !important;
		gap: 8px !important;
	}

	body.page-productos .header-tools .filters-divider {
		display: none !important;
	}
}

/* ===== CATALOG TOOLS WIDTH TUNING v5 (append-last) ===== */
@media (min-width: 861px) {
	body.page-productos .catalog-grid-tools .catalog-grid-tools-inner {
		grid-template-columns: minmax(0, max-content) minmax(38ch, 1fr) auto !important;
		gap: 8px 12px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-count {
		justify-self: start !important;
		width: auto !important;
		min-width: 0 !important;
		max-width: 15ch !important;
		padding: 0 10px !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
		white-space: nowrap !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form {
		justify-self: stretch !important;
		width: 100% !important;
		min-width: 0 !important;
		max-width: none !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form select {
		width: 100% !important;
		min-width: 0 !important;
		max-width: none !important;
		padding-right: 32px !important;
	}
}

/* ===== FILTER UX INTUITIVE v6 (append-last) ===== */
body.page-productos .header-tools .category-mobile-helper {
	display: none;
	margin: 6px 2px 0;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	color: rgba(227, 238, 255, 0.92);
}

body.page-productos .header-tools .category-mobile-helper.is-visible {
	display: block;
}

body.page-productos .catalog-grid-tools .catalog-active-filters {
	grid-column: 1 / -1;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	min-width: 0;
	margin-top: 2px;
}

body.page-productos .catalog-grid-tools .catalog-active-filters.is-empty {
	display: none;
}

body.page-productos .catalog-grid-tools .active-filter-chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	max-width: 100%;
	padding: 6px 10px;
	border-radius: 999px;
	border: 1px solid rgba(133, 178, 255, 0.55);
	background: linear-gradient(135deg, rgba(36, 92, 196, 0.36), rgba(25, 64, 145, 0.28));
	color: #eaf2ff;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: filter 0.16s ease, transform 0.16s ease;
}

body.page-productos .catalog-grid-tools .active-filter-chip:hover {
	filter: brightness(1.06);
	transform: translateY(-1px);
}

body.page-productos .catalog-grid-tools .active-filter-chip-label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

body.page-productos .catalog-grid-tools .active-filter-chip-remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	border-radius: 999px;
	border: 1px solid rgba(186, 212, 255, 0.6);
	background: rgba(16, 43, 101, 0.46);
	color: #ddecff;
	font-size: 0.7rem;
	font-weight: 900;
	line-height: 1;
	flex: 0 0 auto;
}

@media (max-width: 860px) {
	body.page-productos .header-tools .category-mobile-helper {
		font-size: 0.68rem;
		margin-top: 4px;
	}

	body.page-productos .catalog-grid-tools .catalog-active-filters {
		gap: 5px;
	}

	body.page-productos .catalog-grid-tools .active-filter-chip {
		font-size: 0.66rem;
		padding: 5px 9px;
	}
}

/* ===== CATALOG TOOLS COMPACT DESKTOP v7 (append-last) ===== */
@media (min-width: 861px) {
	body.page-productos .catalog-grid-tools {
		padding: 6px 10px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-tools-inner {
		grid-template-columns: max-content minmax(0, 1fr) minmax(220px, 32ch) auto !important;
		align-items: center !important;
		gap: 6px 8px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-count {
		margin: 0 !important;
		justify-self: start !important;
		min-height: 30px !important;
		height: 30px !important;
		padding: 0 8px !important;
		max-width: 17ch !important;
		font-size: 0.67rem !important;
	}

	body.page-productos .catalog-grid-tools .catalog-active-filters {
		grid-column: 2 !important;
		grid-row: 1 !important;
		margin: 0 !important;
		display: flex !important;
		flex-wrap: nowrap !important;
		align-items: center !important;
		gap: 6px !important;
		min-height: 30px !important;
		overflow-x: auto !important;
		overflow-y: hidden !important;
		padding: 0 !important;
	}

	body.page-productos .catalog-grid-tools .catalog-active-filters::-webkit-scrollbar {
		height: 6px;
	}

	body.page-productos .catalog-grid-tools .active-filter-chip {
		flex: 0 0 auto;
		padding: 4px 8px !important;
		font-size: 0.66rem !important;
		min-height: 26px !important;
	}

	body.page-productos .catalog-grid-tools .active-filter-chip-remove {
		width: 15px !important;
		height: 15px !important;
		font-size: 0.62rem !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form {
		grid-column: 3 !important;
		grid-row: 1 !important;
		margin: 0 !important;
		width: 100% !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-order-form select {
		height: 30px !important;
		min-height: 30px !important;
		font-size: 0.68rem !important;
		padding: 0 28px 0 10px !important;
	}

	body.page-productos .catalog-grid-tools .catalog-grid-clear-btn {
		grid-column: 4 !important;
		grid-row: 1 !important;
		min-height: 30px !important;
		height: 30px !important;
		padding: 0 11px !important;
		font-size: 0.67rem !important;
		white-space: nowrap !important;
	}
}
