﻿: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;
}

.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-name {
	width: 50ch;
}

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

.admin-products-table .col-price,
.admin-products-table .col-offer,
.admin-products-table .col-stock {
	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-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-name .admin-inline-name {
	min-width: 50ch;
}

.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;
}

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: rgba(255, 255, 255, 0.98);
	border: 1px solid #cadcfb;
	box-shadow: 0 10px 22px rgba(15, 44, 95, 0.12);
}

.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;
}

.header-tools input,
.header-tools select {
	height: 36px;
	padding-top: 7px;
	padding-bottom: 7px;
}

.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: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(243, 249, 255, 0.97));
	border-color: #c4dafd;
	box-shadow:
		0 10px 24px rgba(9, 35, 83, 0.16),
		inset 0 0 0 1px rgba(255, 255, 255, 0.7);
}

body.has-catalog-tools .header-tools .filters-block label {
	color: #1a4ca9;
}

body.has-catalog-tools .header-tools input,
body.has-catalog-tools .header-tools select {
	border-color: #b8d0f8;
	background: #ffffff;
}

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-name {
	width: 44ch;
}

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

.admin-products-table .col-price,
.admin-products-table .col-offer,
.admin-products-table .col-stock {
	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::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-total {
	margin: 0;
	font-weight: 900;
	letter-spacing: 0.03em;
	color: #123269;
}

.summary-actions {
	margin-top: 10px;
	display: grid;
	grid-template-columns: repeat(2, 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;
	}

	.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;
	}

	.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: auto;
		max-height: 90px;
		object-fit: contain;
		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 {
		max-height: 84px;
	}

	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(4, 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-category-create-form {
	display: grid;
	gap: 10px;
}

.admin-category-create-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

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

.admin-category-row {
	display: grid;
	grid-template-columns: 64px minmax(180px, 1fr) minmax(240px, 1fr) 120px 120px;
	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 {
	align-self: center;
}

.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-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-row {
		grid-template-columns: 1fr;
		align-items: stretch;
	}

	.admin-category-id,
	.admin-category-meta {
		align-self: start;
	}
}

@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;
}

@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;
	}
}
