/*
Theme Name: SMX
Theme URI: https://sistemax.com.py
Description: Child theme base para tiendas WooCommerce de Sistemax.
Author: Sistemax
Author URI: https://sistemax.com.py
Template: twentytwentyfive
Version: 1.0.0
Text Domain: smx
*/

/* ===========================================================================
   SMX - Variables globales
   ========================================================================== */

:root {
	/* Colors */
	--smx-color-primary: #e11d2e;
	--smx-color-primary-dark: #a80f1d;
	--smx-color-primary-light: #ff4054;
	--smx-color-secondary: #334155;
	--smx-color-background: #0b0f14;
	--smx-color-surface: #111827;
	--smx-color-surface-alt: #1f2937;
	--smx-color-header: #070a0f;
	--smx-color-footer: #070a0f;
	--smx-color-card: #111827;
	--smx-color-text: #f8fafc;
	--smx-color-muted: #94a3b8;
	--smx-color-border: rgba(148, 163, 184, 0.22);
	--smx-color-sale: #ef4444;
	--smx-color-success: #22c55e;
	--smx-color-warning: #f59e0b;

	/* Buttons */
	--smx-color-button: var(--smx-color-primary);
	--smx-color-button-text: #ffffff;
	--smx-color-button-hover: var(--smx-color-primary-dark);
	--smx-color-button-hover-text: #ffffff;

	/* Typography */
	--smx-font-body: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--smx-font-heading: var(--smx-font-body);
	--smx-font-size-base: 16px;
	--smx-line-height-base: 1.6;
	--smx-heading-weight: 700;
	--smx-button-weight: 700;
	--smx-font-size-xs: 0.75rem;
	--smx-font-size-sm: 0.875rem;
	--smx-font-size-md: 1rem;
	--smx-font-size-lg: 1.125rem;
	--smx-font-size-xl: 1.25rem;
	--smx-font-size-2xl: 1.5rem;
	--smx-font-size-3xl: 2rem;

	/* Spacing */
	--smx-space-2xs: 0.25rem;
	--smx-space-xs: 0.5rem;
	--smx-space-sm: 0.75rem;
	--smx-space-md: 1rem;
	--smx-space-lg: 1.5rem;
	--smx-space-xl: 2rem;
	--smx-space-2xl: 3rem;
	--smx-space-3xl: 4rem;

	/* Radii */
	--smx-radius-xs: 0.25rem;
	--smx-radius-sm: 0.375rem;
	--smx-radius-md: 0.5rem;
	--smx-radius-lg: 0.75rem;
	--smx-button-radius: var(--smx-radius-md);
	--smx-card-radius: var(--smx-radius-lg);

	/* Shadows */
	--smx-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.28);
	--smx-shadow-md: 0 12px 28px rgba(0, 0, 0, 0.28);
	--smx-shadow-lg: 0 24px 56px rgba(0, 0, 0, 0.36);

	/* Layout */
	--smx-container-max: 1180px;
	--smx-container-wide: 1360px;
	--smx-container-padding: clamp(1rem, 3vw, 2rem);

	/* Transitions */
	--smx-transition-fast: 120ms ease;
	--smx-transition-base: 180ms ease;
	--smx-transition-slow: 260ms ease;
}

/* ===========================================================================
   SMX - Estilos base
   ========================================================================== */

html {
	font-size: var(--smx-font-size-base);
}

body {
	background: var(--smx-color-background);
	color: var(--smx-color-text);
	font-family: var(--smx-font-body);
	font-size: var(--smx-font-size-md);
	line-height: var(--smx-line-height-base);
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

a {
	color: var(--smx-color-primary-light);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
	transition:
		color var(--smx-transition-base),
		text-decoration-color var(--smx-transition-base);
}

a:hover,
a:focus {
	color: var(--smx-color-primary);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid var(--smx-color-primary-light);
	outline-offset: 3px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--smx-color-text);
	font-family: var(--smx-font-heading);
	font-weight: var(--smx-heading-weight);
	line-height: 1.15;
	margin-block: 0 var(--smx-space-md);
}

h1 {
	font-size: clamp(2rem, 4vw, 3rem);
}

h2 {
	font-size: clamp(1.75rem, 3vw, 2.5rem);
}

h3 {
	font-size: var(--smx-font-size-3xl);
}

h4 {
	font-size: var(--smx-font-size-2xl);
}

h5 {
	font-size: var(--smx-font-size-xl);
}

h6 {
	font-size: var(--smx-font-size-lg);
}

p {
	margin-block: 0 var(--smx-space-md);
}

p,
li,
figcaption {
	color: var(--smx-color-text);
}

small,
figcaption {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.wp-element-button,
.wp-block-button__link {
	background: var(--smx-color-button);
	border: 1px solid var(--smx-color-button);
	border-radius: var(--smx-button-radius);
	color: var(--smx-color-button-text);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--smx-font-body);
	font-size: var(--smx-font-size-md);
	font-weight: var(--smx-button-weight);
	line-height: 1.2;
	padding: var(--smx-space-sm) var(--smx-space-lg);
	text-decoration: none;
	transition:
		background-color var(--smx-transition-base),
		border-color var(--smx-transition-base),
		color var(--smx-transition-base),
		transform var(--smx-transition-fast);
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
.wp-element-button:hover,
.wp-block-button__link:hover {
	background: var(--smx-color-button-hover);
	border-color: var(--smx-color-button-hover);
	color: var(--smx-color-button-hover-text);
	transform: translateY(-1px);
}

button:disabled,
input[type="button"]:disabled,
input[type="reset"]:disabled,
input[type="submit"]:disabled {
	cursor: not-allowed;
	opacity: 0.55;
	transform: none;
}

input,
select,
textarea {
	background: var(--smx-color-surface);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-radius-md);
	color: var(--smx-color-text);
	font-family: var(--smx-font-body);
	font-size: var(--smx-font-size-md);
	line-height: 1.4;
	padding: var(--smx-space-sm) var(--smx-space-md);
	transition:
		background-color var(--smx-transition-base),
		border-color var(--smx-transition-base),
		box-shadow var(--smx-transition-base);
}

input::placeholder,
textarea::placeholder {
	color: var(--smx-color-muted);
	opacity: 1;
}

input:focus,
select:focus,
textarea:focus {
	background: var(--smx-color-surface-alt);
	border-color: var(--smx-color-primary-light);
	box-shadow: 0 0 0 3px rgba(225, 29, 46, 0.18);
}

textarea {
	min-height: 8rem;
	resize: vertical;
}

.wp-site-blocks {
	background: var(--smx-color-background);
	min-height: 100vh;
}

.wp-site-blocks > * {
	margin-block-start: 0;
}

.wp-block-group,
.wp-block-columns,
.wp-block-cover,
.entry-content {
	box-sizing: border-box;
}

.wp-block-group.alignwide,
.alignwide {
	max-width: var(--smx-container-wide);
}

.wp-block-group:not(.alignfull),
.entry-content > *:not(.alignfull) {
	margin-inline: auto;
	max-width: var(--smx-container-max);
	padding-inline: var(--smx-container-padding);
}

.alignfull {
	max-width: none;
	width: 100%;
}

/* ===========================================================================
   SMX - WooCommerce basico
   ========================================================================== */

.woocommerce,
.woocommerce-page {
	color: var(--smx-color-text);
}

.woocommerce .woocommerce-products-header,
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
	margin-bottom: var(--smx-space-lg);
}

.woocommerce .woocommerce-products-header__title {
	margin-bottom: var(--smx-space-sm);
}

.woocommerce .woocommerce-result-count {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
}

.woocommerce .woocommerce-ordering select {
	min-width: 13rem;
}

.woocommerce ul.products {
	display: grid;
	gap: var(--smx-space-lg);
	margin: 0;
	padding: 0;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	content: none;
}

.woocommerce ul.products[class*="columns-"] {
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	box-sizing: border-box;
	float: none;
	margin: 0;
	overflow: hidden;
	padding: var(--smx-space-md);
	position: relative;
	transition:
		border-color var(--smx-transition-base),
		box-shadow var(--smx-transition-base),
		transform var(--smx-transition-base);
	width: auto;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
	border-color: rgba(255, 64, 84, 0.42);
	box-shadow: var(--smx-shadow-md);
	transform: translateY(-2px);
}

.woocommerce ul.products li.product a {
	color: inherit;
	text-decoration: none;
}

.woocommerce ul.products li.product a img {
	aspect-ratio: 1 / 1;
	background: var(--smx-color-surface-alt);
	border-radius: var(--smx-radius-md);
	display: block;
	height: auto;
	margin: 0 0 var(--smx-space-md);
	object-fit: cover;
	width: 100%;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	color: var(--smx-color-text);
	font-size: var(--smx-font-size-lg);
	line-height: 1.25;
	margin: 0 0 var(--smx-space-xs);
	padding: 0;
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--smx-color-text);
	display: block;
	font-size: var(--smx-font-size-lg);
	font-weight: var(--smx-heading-weight);
	margin-bottom: var(--smx-space-md);
}

.woocommerce ul.products li.product .price del,
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
	font-weight: 400;
	opacity: 0.8;
}

.woocommerce ul.products li.product .price ins,
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
	color: var(--smx-color-sale);
	text-decoration: none;
}

.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
	background: var(--smx-color-sale);
	border-radius: 999px;
	box-shadow: var(--smx-shadow-sm);
	color: #ffffff;
	font-size: var(--smx-font-size-xs);
	font-weight: var(--smx-button-weight);
	left: var(--smx-space-md);
	line-height: 1;
	margin: 0;
	min-height: auto;
	min-width: auto;
	padding: var(--smx-space-xs) var(--smx-space-sm);
	position: absolute;
	right: auto;
	text-transform: uppercase;
	top: var(--smx-space-md);
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce #payment #place_order,
.woocommerce-page #payment #place_order {
	background: var(--smx-color-button);
	border: 1px solid var(--smx-color-button);
	border-radius: var(--smx-button-radius);
	color: var(--smx-color-button-text);
	font-family: var(--smx-font-body);
	font-size: var(--smx-font-size-md);
	font-weight: var(--smx-button-weight);
	line-height: 1.2;
	padding: var(--smx-space-sm) var(--smx-space-lg);
	text-decoration: none;
	transition:
		background-color var(--smx-transition-base),
		border-color var(--smx-transition-base),
		color var(--smx-transition-base),
		transform var(--smx-transition-fast);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce #payment #place_order:hover,
.woocommerce-page #payment #place_order:hover {
	background: var(--smx-color-button-hover);
	border-color: var(--smx-color-button-hover);
	color: var(--smx-color-button-hover-text);
	transform: translateY(-1px);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
	background: var(--smx-color-primary);
	border-color: var(--smx-color-primary);
	color: var(--smx-color-button-text);
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover {
	background: var(--smx-color-primary-dark);
	border-color: var(--smx-color-primary-dark);
	color: var(--smx-color-button-hover-text);
}

.woocommerce table.shop_table {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-collapse: separate;
	border-radius: var(--smx-card-radius);
	overflow: hidden;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	border-color: var(--smx-color-border);
	color: var(--smx-color-text);
	padding: var(--smx-space-md);
}

.woocommerce table.shop_table th {
	background: var(--smx-color-surface-alt);
	font-weight: var(--smx-heading-weight);
}

.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review,
.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	padding: var(--smx-space-lg);
}

.woocommerce form .form-row label {
	color: var(--smx-color-text);
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	margin-bottom: var(--smx-space-xs);
}

.woocommerce form .form-row .required {
	color: var(--smx-color-primary-light);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	width: 100%;
}

.woocommerce .quantity .qty {
	max-width: 5.5rem;
	text-align: center;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	color: var(--smx-color-text);
	margin-bottom: var(--smx-space-lg);
	padding: var(--smx-space-md) var(--smx-space-lg);
}

.woocommerce-message {
	border-top-color: var(--smx-color-success);
}

.woocommerce-info {
	border-top-color: var(--smx-color-primary-light);
}

.woocommerce-error {
	border-top-color: var(--smx-color-sale);
}

.woocommerce-message::before {
	color: var(--smx-color-success);
}

.woocommerce-info::before {
	color: var(--smx-color-primary-light);
}

.woocommerce-error::before {
	color: var(--smx-color-sale);
}

.woocommerce #payment {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
}

.woocommerce #payment div.payment_box {
	background: var(--smx-color-surface);
	color: var(--smx-color-text);
}

.woocommerce #payment div.payment_box::before {
	border-bottom-color: var(--smx-color-surface);
}

@media (max-width: 640px) {
	.woocommerce ul.products[class*="columns-"] {
		grid-template-columns: 1fr;
	}

	.woocommerce-cart .cart-collaterals .cart_totals,
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review,
	.woocommerce form.checkout_coupon,
	.woocommerce form.login,
	.woocommerce form.register {
		padding: var(--smx-space-md);
	}
}

/* ===========================================================================
   SMX - Componentes visuales reutilizables
   ========================================================================== */

.smx-section {
	padding-block: var(--smx-space-3xl);
}

.smx-section--surface {
	background: var(--smx-color-surface);
}

.smx-section__inner {
	box-sizing: border-box;
	margin-inline: auto;
	max-width: var(--smx-container-max);
	padding-inline: var(--smx-container-padding);
}

.smx-section__header {
	margin-bottom: var(--smx-space-xl);
	max-width: 720px;
}

.smx-section__eyebrow {
	color: var(--smx-color-primary-light);
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	letter-spacing: 0;
	margin-bottom: var(--smx-space-xs);
	text-transform: uppercase;
}

.smx-section__title {
	margin-bottom: var(--smx-space-sm);
}

.smx-section__text {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-lg);
	margin-bottom: 0;
}

.smx-hero {
	align-items: center;
	background:
		linear-gradient(90deg, rgba(7, 10, 15, 0.92), rgba(7, 10, 15, 0.62)),
		var(--smx-color-surface);
	box-sizing: border-box;
	display: grid;
	min-height: clamp(30rem, 72vh, 44rem);
	overflow: hidden;
	padding-block: var(--smx-space-3xl);
	position: relative;
}

.smx-hero--image {
	background-position: center;
	background-size: cover;
}

.smx-hero__inner {
	box-sizing: border-box;
	margin-inline: auto;
	max-width: var(--smx-container-max);
	padding-inline: var(--smx-container-padding);
	position: relative;
	width: 100%;
	z-index: 1;
}

.smx-hero__content {
	max-width: 680px;
}

.smx-hero__eyebrow {
	color: var(--smx-color-primary-light);
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	letter-spacing: 0;
	margin-bottom: var(--smx-space-sm);
	text-transform: uppercase;
}

.smx-hero__title {
	font-size: clamp(2.4rem, 7vw, 5rem);
	margin-bottom: var(--smx-space-md);
}

.smx-hero__text {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-xl);
	margin-bottom: var(--smx-space-xl);
	max-width: 620px;
}

.smx-hero__actions,
.smx-banner__actions,
.smx-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--smx-space-sm);
}

.smx-button-secondary {
	background: transparent;
	border-color: var(--smx-color-border);
	color: var(--smx-color-text);
}

.smx-button-secondary:hover,
.smx-button-secondary:focus {
	background: var(--smx-color-surface-alt);
	border-color: var(--smx-color-primary-light);
	color: var(--smx-color-text);
}

.smx-banner {
	align-items: center;
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	box-sizing: border-box;
	display: grid;
	gap: var(--smx-space-lg);
	grid-template-columns: minmax(0, 1fr) auto;
	padding: var(--smx-space-xl);
}

.smx-banner--accent {
	background:
		linear-gradient(135deg, rgba(225, 29, 46, 0.2), rgba(17, 24, 39, 0.96)),
		var(--smx-color-card);
	border-color: rgba(255, 64, 84, 0.34);
}

.smx-banner__title {
	font-size: var(--smx-font-size-2xl);
	margin-bottom: var(--smx-space-xs);
}

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

.smx-grid {
	display: grid;
	gap: var(--smx-space-lg);
}

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

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

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

.smx-card {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	box-sizing: border-box;
	color: var(--smx-color-text);
	overflow: hidden;
	padding: var(--smx-space-lg);
	position: relative;
	transition:
		border-color var(--smx-transition-base),
		box-shadow var(--smx-transition-base),
		transform var(--smx-transition-base);
}

.smx-card:hover {
	border-color: rgba(255, 64, 84, 0.34);
	box-shadow: var(--smx-shadow-md);
	transform: translateY(-2px);
}

.smx-card__media {
	aspect-ratio: 16 / 10;
	background: var(--smx-color-surface-alt);
	border-radius: var(--smx-radius-md);
	margin-bottom: var(--smx-space-md);
	overflow: hidden;
}

.smx-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.smx-card__title {
	font-size: var(--smx-font-size-xl);
	margin-bottom: var(--smx-space-xs);
}

.smx-card__text {
	color: var(--smx-color-muted);
	margin-bottom: var(--smx-space-md);
}

.smx-card--image {
	align-items: end;
	aspect-ratio: 4 / 3;
	background:
		linear-gradient(180deg, rgba(7, 10, 15, 0.18), rgba(7, 10, 15, 0.9)),
		var(--smx-color-card);
	background-position: center;
	background-size: cover;
	display: flex;
	min-height: 18rem;
	padding: var(--smx-space-xl);
}

.smx-card--image .smx-card__content {
	position: relative;
	z-index: 1;
}

.smx-category-card {
	align-items: center;
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	box-sizing: border-box;
	color: var(--smx-color-text);
	display: flex;
	gap: var(--smx-space-md);
	padding: var(--smx-space-md);
	text-decoration: none;
	transition:
		border-color var(--smx-transition-base),
		background-color var(--smx-transition-base),
		transform var(--smx-transition-base);
}

.smx-category-card:hover,
.smx-category-card:focus {
	background: var(--smx-color-surface-alt);
	border-color: rgba(255, 64, 84, 0.34);
	color: var(--smx-color-text);
	transform: translateY(-2px);
}

.smx-category-card__image {
	aspect-ratio: 1;
	background: var(--smx-color-surface-alt);
	border-radius: var(--smx-radius-md);
	flex: 0 0 4.5rem;
	overflow: hidden;
}

.smx-category-card__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.smx-category-card__title {
	font-size: var(--smx-font-size-lg);
	margin-bottom: var(--smx-space-2xs);
}

.smx-category-card__meta {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
	margin: 0;
}

.smx-products-section {
	padding-block: var(--smx-space-3xl);
}

.smx-products-section__header {
	align-items: end;
	display: flex;
	gap: var(--smx-space-lg);
	justify-content: space-between;
	margin-bottom: var(--smx-space-xl);
}

.smx-products-section__title {
	margin-bottom: 0;
}

.smx-products-section__link {
	font-weight: var(--smx-button-weight);
	white-space: nowrap;
}

.smx-badge {
	align-items: center;
	background: rgba(225, 29, 46, 0.14);
	border: 1px solid rgba(255, 64, 84, 0.34);
	border-radius: 999px;
	color: var(--smx-color-primary-light);
	display: inline-flex;
	font-size: var(--smx-font-size-xs);
	font-weight: var(--smx-button-weight);
	gap: var(--smx-space-xs);
	line-height: 1;
	padding: var(--smx-space-xs) var(--smx-space-sm);
	text-transform: uppercase;
}

.smx-badge--muted {
	background: var(--smx-color-surface);
	border-color: var(--smx-color-border);
	color: var(--smx-color-muted);
}

.smx-benefits {
	display: grid;
	gap: var(--smx-space-md);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.smx-benefit {
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-card-radius);
	box-shadow: var(--smx-shadow-sm);
	padding: var(--smx-space-lg);
}

.smx-benefit__icon {
	align-items: center;
	background: rgba(225, 29, 46, 0.14);
	border-radius: var(--smx-radius-md);
	color: var(--smx-color-primary-light);
	display: inline-flex;
	font-size: var(--smx-font-size-xl);
	font-weight: var(--smx-heading-weight);
	height: 2.75rem;
	justify-content: center;
	margin-bottom: var(--smx-space-md);
	width: 2.75rem;
}

.smx-benefit__title {
	font-size: var(--smx-font-size-lg);
	margin-bottom: var(--smx-space-xs);
}

.smx-benefit__text {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
	margin-bottom: 0;
}

.smx-brands {
	align-items: center;
	display: grid;
	gap: var(--smx-space-md);
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.smx-brand {
	align-items: center;
	background: var(--smx-color-card);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-radius-md);
	color: var(--smx-color-muted);
	display: flex;
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	justify-content: center;
	min-height: 5rem;
	padding: var(--smx-space-md);
	text-align: center;
}

.smx-brand img {
	display: block;
	filter: grayscale(1);
	max-height: 2.5rem;
	max-width: 100%;
	opacity: 0.78;
}

@media (max-width: 900px) {
	.smx-grid--3,
	.smx-grid--4,
	.smx-benefits,
	.smx-brands {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.smx-banner,
	.smx-products-section__header {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.smx-products-section__header {
		flex-direction: column;
	}
}

@media (max-width: 640px) {
	.smx-section,
	.smx-products-section {
		padding-block: var(--smx-space-2xl);
	}

	.smx-hero {
		min-height: auto;
		padding-block: var(--smx-space-3xl);
	}

	.smx-hero__title {
		font-size: clamp(2rem, 12vw, 3rem);
	}

	.smx-hero__text,
	.smx-section__text {
		font-size: var(--smx-font-size-md);
	}

	.smx-grid--2,
	.smx-grid--3,
	.smx-grid--4,
	.smx-benefits,
	.smx-brands {
		grid-template-columns: 1fr;
	}

	.smx-banner,
	.smx-card,
	.smx-card--image,
	.smx-benefit {
		padding: var(--smx-space-md);
	}

	.smx-card--image {
		min-height: 16rem;
	}
}

/* ===========================================================================
   SMX - Header
   ========================================================================== */

.wp-site-blocks > header,
.wp-block-template-part:has(header),
.smx-header {
	background: var(--smx-color-header);
	border-bottom: 1px solid var(--smx-color-border);
	color: var(--smx-color-text);
	position: relative;
	z-index: 20;
}

.wp-site-blocks > header a,
.wp-block-template-part:has(header) a,
.smx-header a {
	color: var(--smx-color-text);
	text-decoration: none;
}

.wp-site-blocks > header a:hover,
.wp-site-blocks > header a:focus,
.wp-block-template-part:has(header) a:hover,
.wp-block-template-part:has(header) a:focus,
.smx-header a:hover,
.smx-header a:focus {
	color: var(--smx-color-primary-light);
}

.smx-header__inner,
.wp-site-blocks > header > .wp-block-group,
.wp-block-template-part:has(header) > .wp-block-group {
	align-items: center;
	box-sizing: border-box;
	display: flex;
	gap: var(--smx-space-lg);
	justify-content: space-between;
	margin-inline: auto;
	max-width: var(--smx-container-wide);
	min-height: 5rem;
	padding: var(--smx-space-md) var(--smx-container-padding);
	width: 100%;
}

.smx-header__brand,
.wp-site-blocks > header .wp-block-site-logo,
.wp-site-blocks > header .wp-block-site-title,
.wp-block-template-part:has(header) .wp-block-site-logo,
.wp-block-template-part:has(header) .wp-block-site-title {
	flex: 0 0 auto;
}

.wp-site-blocks > header .wp-block-site-title,
.wp-block-template-part:has(header) .wp-block-site-title,
.smx-header__brand-name {
	font-family: var(--smx-font-heading);
	font-size: var(--smx-font-size-xl);
	font-weight: var(--smx-heading-weight);
	line-height: 1.1;
	margin: 0;
}

.wp-site-blocks > header .wp-block-site-title a,
.wp-block-template-part:has(header) .wp-block-site-title a,
.smx-header__brand-name a {
	color: var(--smx-color-text);
}

.wp-site-blocks > header .wp-block-site-logo img,
.wp-block-template-part:has(header) .wp-block-site-logo img,
.smx-header__logo img {
	display: block;
	height: auto;
	max-height: 3rem;
	width: auto;
}

.smx-header__nav,
.wp-site-blocks > header .wp-block-navigation,
.wp-block-template-part:has(header) .wp-block-navigation {
	align-items: center;
	display: flex;
	flex: 1 1 auto;
	justify-content: center;
}

.wp-site-blocks > header .wp-block-navigation__container,
.wp-block-template-part:has(header) .wp-block-navigation__container,
.smx-header__menu {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--smx-space-xs);
	justify-content: center;
}

.wp-site-blocks > header .wp-block-navigation-item__content,
.wp-block-template-part:has(header) .wp-block-navigation-item__content,
.smx-header__menu a {
	border-radius: var(--smx-radius-md);
	color: var(--smx-color-text);
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	padding: var(--smx-space-xs) var(--smx-space-sm);
	transition:
		background-color var(--smx-transition-base),
		color var(--smx-transition-base);
}

.wp-site-blocks > header .wp-block-navigation-item__content:hover,
.wp-site-blocks > header .wp-block-navigation-item__content:focus,
.wp-block-template-part:has(header) .wp-block-navigation-item__content:hover,
.wp-block-template-part:has(header) .wp-block-navigation-item__content:focus,
.smx-header__menu a:hover,
.smx-header__menu a:focus {
	background: var(--smx-color-surface-alt);
	color: var(--smx-color-primary-light);
}

.smx-header__search,
.wp-site-blocks > header .wp-block-search,
.wp-block-template-part:has(header) .wp-block-search {
	flex: 1 1 18rem;
	max-width: 26rem;
	min-width: 14rem;
}

.wp-site-blocks > header .wp-block-search__inside-wrapper,
.wp-block-template-part:has(header) .wp-block-search__inside-wrapper,
.smx-header__search-form {
	align-items: center;
	background: var(--smx-color-surface);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-button-radius);
	display: flex;
	gap: var(--smx-space-xs);
	overflow: hidden;
	padding: var(--smx-space-2xs);
}

.wp-site-blocks > header .wp-block-search__input,
.wp-block-template-part:has(header) .wp-block-search__input,
.smx-header__search-input {
	background: transparent;
	border: 0;
	box-shadow: none;
	color: var(--smx-color-text);
	flex: 1 1 auto;
	min-width: 0;
	padding: var(--smx-space-xs) var(--smx-space-sm);
}

.wp-site-blocks > header .wp-block-search__input:focus,
.wp-block-template-part:has(header) .wp-block-search__input:focus,
.smx-header__search-input:focus {
	background: transparent;
	box-shadow: none;
}

.wp-site-blocks > header .wp-block-search__button,
.wp-block-template-part:has(header) .wp-block-search__button,
.smx-header__search-button {
	border-radius: var(--smx-radius-sm);
	flex: 0 0 auto;
	padding: var(--smx-space-xs) var(--smx-space-sm);
}

.smx-header__actions {
	align-items: center;
	display: flex;
	flex: 0 0 auto;
	gap: var(--smx-space-sm);
	justify-content: flex-end;
}

.smx-header__cart,
.wp-site-blocks > header .wc-block-mini-cart__button,
.wp-block-template-part:has(header) .wc-block-mini-cart__button {
	align-items: center;
	background: var(--smx-color-surface);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-button-radius);
	color: var(--smx-color-text);
	display: inline-flex;
	font-weight: var(--smx-button-weight);
	gap: var(--smx-space-xs);
	justify-content: center;
	min-height: 2.75rem;
	padding: var(--smx-space-xs) var(--smx-space-sm);
	transition:
		background-color var(--smx-transition-base),
		border-color var(--smx-transition-base),
		color var(--smx-transition-base);
}

.smx-header__cart:hover,
.smx-header__cart:focus,
.wp-site-blocks > header .wc-block-mini-cart__button:hover,
.wp-site-blocks > header .wc-block-mini-cart__button:focus,
.wp-block-template-part:has(header) .wc-block-mini-cart__button:hover,
.wp-block-template-part:has(header) .wc-block-mini-cart__button:focus {
	background: var(--smx-color-primary);
	border-color: var(--smx-color-primary);
	color: var(--smx-color-button-text);
}

.smx-header__cart-count,
.wp-site-blocks > header .wc-block-mini-cart__badge,
.wp-block-template-part:has(header) .wc-block-mini-cart__badge {
	align-items: center;
	background: var(--smx-color-primary);
	border-radius: 999px;
	color: var(--smx-color-button-text);
	display: inline-flex;
	font-size: var(--smx-font-size-xs);
	font-weight: var(--smx-button-weight);
	justify-content: center;
	line-height: 1;
	min-height: 1.25rem;
	min-width: 1.25rem;
	padding: var(--smx-space-2xs);
}

.wp-site-blocks > header .wp-block-navigation__responsive-container-open,
.wp-block-template-part:has(header) .wp-block-navigation__responsive-container-open {
	background: var(--smx-color-surface);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-button-radius);
	color: var(--smx-color-text);
	padding: var(--smx-space-xs);
}

.wp-site-blocks > header .wp-block-navigation__responsive-container,
.wp-block-template-part:has(header) .wp-block-navigation__responsive-container {
	background: var(--smx-color-header);
	color: var(--smx-color-text);
}

.wp-site-blocks > header .wp-block-navigation__responsive-container-close,
.wp-block-template-part:has(header) .wp-block-navigation__responsive-container-close {
	color: var(--smx-color-text);
}

@media (max-width: 900px) {
	.smx-header__inner,
	.wp-site-blocks > header > .wp-block-group,
	.wp-block-template-part:has(header) > .wp-block-group {
		align-items: stretch;
		flex-wrap: wrap;
		gap: var(--smx-space-md);
	}

	.smx-header__nav,
	.wp-site-blocks > header .wp-block-navigation,
	.wp-block-template-part:has(header) .wp-block-navigation {
		justify-content: flex-start;
		order: 3;
		width: 100%;
	}

	.smx-header__search,
	.wp-site-blocks > header .wp-block-search,
	.wp-block-template-part:has(header) .wp-block-search {
		flex-basis: 100%;
		max-width: none;
		order: 4;
	}
}

@media (max-width: 640px) {
	.smx-header__inner,
	.wp-site-blocks > header > .wp-block-group,
	.wp-block-template-part:has(header) > .wp-block-group {
		min-height: auto;
		padding-block: var(--smx-space-sm);
	}

	.wp-site-blocks > header .wp-block-site-title,
	.wp-block-template-part:has(header) .wp-block-site-title,
	.smx-header__brand-name {
		font-size: var(--smx-font-size-lg);
	}

	.wp-site-blocks > header .wp-block-navigation__container,
	.wp-block-template-part:has(header) .wp-block-navigation__container,
	.smx-header__menu {
		align-items: stretch;
		flex-direction: column;
		width: 100%;
	}

	.wp-site-blocks > header .wp-block-navigation-item__content,
	.wp-block-template-part:has(header) .wp-block-navigation-item__content,
	.smx-header__menu a {
		width: 100%;
	}

	.smx-header__actions {
		margin-left: auto;
	}
}

/* ===========================================================================
   SMX - Footer
   ========================================================================== */

.wp-site-blocks > footer,
.wp-block-template-part:has(footer),
.smx-footer {
	background: var(--smx-color-footer);
	border-top: 1px solid var(--smx-color-border);
	color: var(--smx-color-text);
}

.wp-site-blocks > footer a,
.wp-block-template-part:has(footer) a,
.smx-footer a {
	color: var(--smx-color-muted);
	text-decoration: none;
	transition:
		color var(--smx-transition-base),
		text-decoration-color var(--smx-transition-base);
}

.wp-site-blocks > footer a:hover,
.wp-site-blocks > footer a:focus,
.wp-block-template-part:has(footer) a:hover,
.wp-block-template-part:has(footer) a:focus,
.smx-footer a:hover,
.smx-footer a:focus {
	color: var(--smx-color-primary-light);
}

.smx-footer__inner,
.wp-site-blocks > footer > .wp-block-group,
.wp-block-template-part:has(footer) > .wp-block-group {
	box-sizing: border-box;
	margin-inline: auto;
	max-width: var(--smx-container-wide);
	padding: var(--smx-space-3xl) var(--smx-container-padding) var(--smx-space-xl);
	width: 100%;
}

.smx-footer__grid {
	display: grid;
	gap: var(--smx-space-2xl);
	grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.85fr) minmax(0, 1fr);
}

.smx-footer__brand {
	max-width: 28rem;
}

.smx-footer__logo,
.wp-site-blocks > footer .wp-block-site-logo,
.wp-block-template-part:has(footer) .wp-block-site-logo {
	margin-bottom: var(--smx-space-md);
}

.smx-footer__logo img,
.wp-site-blocks > footer .wp-block-site-logo img,
.wp-block-template-part:has(footer) .wp-block-site-logo img {
	display: block;
	height: auto;
	max-height: 3rem;
	width: auto;
}

.smx-footer__title,
.wp-site-blocks > footer .wp-block-heading,
.wp-block-template-part:has(footer) .wp-block-heading {
	color: var(--smx-color-text);
	font-size: var(--smx-font-size-lg);
	margin-bottom: var(--smx-space-md);
}

.smx-footer__text,
.wp-site-blocks > footer p,
.wp-block-template-part:has(footer) p {
	color: var(--smx-color-muted);
	margin-bottom: var(--smx-space-md);
}

.smx-footer__email {
	color: var(--smx-color-primary-light);
	font-weight: var(--smx-button-weight);
}

.smx-footer__list,
.wp-site-blocks > footer ul,
.wp-block-template-part:has(footer) ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.smx-footer__list li,
.wp-site-blocks > footer li,
.wp-block-template-part:has(footer) li {
	color: var(--smx-color-muted);
	margin-bottom: var(--smx-space-sm);
}

.smx-footer__social {
	display: flex;
	flex-wrap: wrap;
	gap: var(--smx-space-sm);
}

.smx-footer__social a,
.wp-site-blocks > footer .wp-block-social-links .wp-social-link a,
.wp-block-template-part:has(footer) .wp-block-social-links .wp-social-link a {
	align-items: center;
	background: var(--smx-color-surface);
	border: 1px solid var(--smx-color-border);
	border-radius: var(--smx-button-radius);
	color: var(--smx-color-text);
	display: inline-flex;
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
	justify-content: center;
	min-height: 2.75rem;
	min-width: 2.75rem;
	padding: var(--smx-space-xs) var(--smx-space-sm);
}

.smx-footer__social a:hover,
.smx-footer__social a:focus,
.wp-site-blocks > footer .wp-block-social-links .wp-social-link a:hover,
.wp-site-blocks > footer .wp-block-social-links .wp-social-link a:focus,
.wp-block-template-part:has(footer) .wp-block-social-links .wp-social-link a:hover,
.wp-block-template-part:has(footer) .wp-block-social-links .wp-social-link a:focus {
	background: var(--smx-color-primary);
	border-color: var(--smx-color-primary);
	color: var(--smx-color-button-text);
}

.wp-site-blocks > footer .wp-block-social-links,
.wp-block-template-part:has(footer) .wp-block-social-links {
	gap: var(--smx-space-sm);
}

.wp-site-blocks > footer .wp-block-social-links .wp-social-link,
.wp-block-template-part:has(footer) .wp-block-social-links .wp-social-link {
	background: transparent;
	color: inherit;
}

.smx-footer__contact {
	display: grid;
	gap: var(--smx-space-sm);
}

.smx-footer__contact-item {
	color: var(--smx-color-muted);
	display: grid;
	gap: var(--smx-space-2xs);
}

.smx-footer__contact-label {
	color: var(--smx-color-text);
	font-size: var(--smx-font-size-sm);
	font-weight: var(--smx-button-weight);
}

.smx-footer__whatsapp {
	color: var(--smx-color-success);
	font-weight: var(--smx-button-weight);
}

.smx-footer__bottom {
	align-items: center;
	border-top: 1px solid var(--smx-color-border);
	display: flex;
	gap: var(--smx-space-md);
	justify-content: space-between;
	margin-top: var(--smx-space-2xl);
	padding-top: var(--smx-space-lg);
}

.smx-footer__copyright,
.wp-site-blocks > footer .wp-block-site-title,
.wp-block-template-part:has(footer) .wp-block-site-title {
	color: var(--smx-color-muted);
	font-size: var(--smx-font-size-sm);
	margin: 0;
}

.smx-footer__legal {
	display: flex;
	flex-wrap: wrap;
	gap: var(--smx-space-md);
}

.smx-footer__legal a {
	font-size: var(--smx-font-size-sm);
}

@media (max-width: 900px) {
	.smx-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.smx-footer__brand {
		grid-column: 1 / -1;
	}
}

@media (max-width: 640px) {
	.smx-footer__inner,
	.wp-site-blocks > footer > .wp-block-group,
	.wp-block-template-part:has(footer) > .wp-block-group {
		padding-block: var(--smx-space-2xl) var(--smx-space-lg);
	}

	.smx-footer__grid {
		gap: var(--smx-space-xl);
		grid-template-columns: 1fr;
	}

	.smx-footer__brand {
		grid-column: auto;
	}

	.smx-footer__bottom {
		align-items: flex-start;
		flex-direction: column;
	}

	.smx-footer__legal {
		gap: var(--smx-space-sm);
	}
}

/* ===========================================================================
   SMX - Responsive
   ========================================================================== */

img,
video,
iframe {
	max-width: 100%;
}

img,
video {
	height: auto;
}

@media (max-width: 1180px) {
	.wp-block-columns {
		gap: var(--smx-space-lg);
	}

	.woocommerce ul.products[class*="columns-"] {
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	}

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

@media (max-width: 782px) {
	body {
		font-size: var(--smx-font-size-md);
	}

	h1 {
		font-size: clamp(2rem, 9vw, 2.75rem);
	}

	h2 {
		font-size: clamp(1.65rem, 7vw, 2.25rem);
	}

	h3 {
		font-size: var(--smx-font-size-2xl);
	}

	.wp-block-columns:not(.is-not-stacked-on-mobile) {
		gap: var(--smx-space-lg);
	}

	.wp-block-media-text {
		grid-template-columns: 1fr !important;
	}

	.wp-block-media-text .wp-block-media-text__content {
		padding: var(--smx-space-lg) 0 0;
	}

	.wp-block-group:not(.alignfull),
	.entry-content > *:not(.alignfull),
	.smx-section__inner,
	.smx-hero__inner {
		padding-inline: var(--smx-container-padding);
	}

	.smx-banner,
	.smx-products-section__header {
		gap: var(--smx-space-md);
	}

	.woocommerce .woocommerce-result-count,
	.woocommerce .woocommerce-ordering {
		float: none;
		width: 100%;
	}

	.woocommerce .woocommerce-ordering select {
		width: 100%;
	}

	.woocommerce table.shop_table_responsive tr,
	.woocommerce-page table.shop_table_responsive tr {
		border-bottom: 1px solid var(--smx-color-border);
	}

	.woocommerce table.shop_table_responsive tr td,
	.woocommerce-page table.shop_table_responsive tr td {
		border-top: 0;
		display: block;
		text-align: right;
	}

	.woocommerce table.shop_table_responsive tr td::before,
	.woocommerce-page table.shop_table_responsive tr td::before {
		color: var(--smx-color-muted);
		float: left;
		font-weight: var(--smx-button-weight);
	}

	.woocommerce-cart table.cart td.actions .coupon,
	.woocommerce-cart table.cart td.actions .coupon .input-text {
		width: 100%;
	}

	.woocommerce-cart table.cart td.actions .button {
		margin-top: var(--smx-space-sm);
		width: 100%;
	}
}

@media (max-width: 640px) {
	:root {
		--smx-container-padding: 1rem;
	}

	body {
		overflow-x: hidden;
	}

	p,
	li {
		overflow-wrap: anywhere;
	}

	button,
	input[type="button"],
	input[type="reset"],
	input[type="submit"],
	.wp-element-button,
	.wp-block-button__link,
	.woocommerce a.button,
	.woocommerce button.button,
	.woocommerce input.button,
	.woocommerce #respond input#submit {
		width: 100%;
	}

	input,
	select,
	textarea {
		width: 100%;
	}

	.wp-block-buttons,
	.smx-hero__actions,
	.smx-banner__actions,
	.smx-card__actions {
		align-items: stretch;
		flex-direction: column;
		width: 100%;
	}

	.wp-block-button,
	.wp-block-button__link {
		width: 100%;
	}

	.wp-block-cover {
		min-height: 24rem;
		padding: var(--smx-space-xl) var(--smx-container-padding);
	}

	.wp-block-cover__inner-container {
		width: 100%;
	}

	.smx-section__header,
	.smx-hero__content {
		max-width: none;
	}

	.smx-category-card {
		align-items: flex-start;
	}

	.smx-category-card__image {
		flex-basis: 3.75rem;
	}

	.smx-products-section__link {
		white-space: normal;
	}

	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product {
		padding: var(--smx-space-sm);
	}

	.woocommerce ul.products li.product .woocommerce-loop-product__title {
		font-size: var(--smx-font-size-md);
	}

	.woocommerce ul.products li.product .price,
	.woocommerce div.product p.price,
	.woocommerce div.product span.price {
		font-size: var(--smx-font-size-md);
	}

	.woocommerce span.onsale,
	.woocommerce ul.products li.product .onsale {
		left: var(--smx-space-sm);
		top: var(--smx-space-sm);
	}

	.woocommerce-cart .cart-collaterals .cart_totals,
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review {
		margin-top: var(--smx-space-lg);
	}
}

@media (max-width: 420px) {
	h1 {
		font-size: clamp(1.85rem, 12vw, 2.35rem);
	}

	h2 {
		font-size: clamp(1.5rem, 10vw, 2rem);
	}

	.smx-banner,
	.smx-card,
	.smx-card--image,
	.smx-benefit,
	.woocommerce-cart .cart-collaterals .cart_totals,
	.woocommerce-checkout #customer_details,
	.woocommerce-checkout #order_review,
	.woocommerce form.checkout_coupon,
	.woocommerce form.login,
	.woocommerce form.register {
		border-radius: var(--smx-radius-md);
	}

	.smx-header__actions,
	.smx-footer__social,
	.smx-footer__legal {
		width: 100%;
	}

	.smx-header__cart,
	.wp-site-blocks > header .wc-block-mini-cart__button,
	.wp-block-template-part:has(header) .wc-block-mini-cart__button {
		width: 100%;
	}
}
