/* ==========================================================================
   Mattis Elementor Addons - Main Styles
   ========================================================================== */

/* Google Fonts - DM Sans */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap');

/* CSS Custom Properties - Mattis Color Palette */
:root {
	/* Primary Palette */
	--mattis-primary: #db7e2b;
	--mattis-primary-hover: #db7e2b;
	--mattis-primary-active: #c86215;
	--mattis-dark: #131316;
	--mattis-light: #f7f8fb;
	--mattis-white: #ffffff;
	--mattis-black: #000000;

	/* Secondary Palette */
	--mattis-secondary: #e8412a;
	--mattis-secondary-hover: #d73626;
	--mattis-secondary-active: #c62b1f;

	/* Surfaces & Borders */
	--mattis-surface: #ffffff;
	--mattis-surface-alt: #f4f5f8;
	--mattis-surface-muted: #fafbff;
	--mattis-border-soft: #eceef2;
	--mattis-border-strong: #cfd3dd;

	/* Secondary Grays */
	--mattis-gray-1: #4a4b4f;
	--mattis-gray-2: #5c5d60;
	--mattis-gray-3: #6a6b6f;
	--mattis-gray-4: #808288;
	--mattis-gray-5: #b6b8be;
	--mattis-gray-6: #c6c8ce;
	--mattis-gray-7: #dadddf;
	--mattis-gray-8: #e6e8ed;
	--mattis-gray-9: #eff1f6;
	--mattis-gray-10: #f6f7fb;

	/* Accent Colors */
	--mattis-purple: #1c1737;
	--mattis-red: #e8412a;
	--mattis-red-alt: #e8462f;
	--mattis-green: #2ec055;
	--mattis-orange: #e08740;
	--mattis-gold: #dac786;
	--mattis-dark-alt: #1d1d1d;

	/* Transparent Colors */
	--mattis-dark-80: #15151580;
	--mattis-white-60: #ffffff99;
	--mattis-white-50: #ffffff80;
	--mattis-black-10: #0000001a;

	/* Gradients */
	--mattis-gradient-1: linear-gradient(90deg, #464796 0.01%, #cc589b 99.99%);
	--mattis-gradient-2: linear-gradient(90deg, #e8ad77 0%, #cc589b 100%);
	--mattis-gradient-radial: radial-gradient(
		50% 50% at 50% 50%,
		rgba(232, 65, 42, 0.5) 0%,
		rgba(232, 65, 42, 0) 100%
	);

	/* Typography */
	--mattis-font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI',
		Roboto, sans-serif;
	--mattis-font-size-base: 16px;
	--mattis-line-height-base: 1.5;

	/* Spacing */
	--mattis-space-xs: 8px;
	--mattis-space-sm: 16px;
	--mattis-space-md: 24px;
	--mattis-space-lg: 32px;
	--mattis-space-xl: 48px;
	--mattis-space-xxl: 64px;

	/* Border Radius */
	--mattis-radius-sm: 4px;
	--mattis-radius-md: 10px;
	--mattis-radius-lg: 24px;
	--mattis-radius-xl: 32px;
	--mattis-radius-xxl: 48px;

	/* Shadows */
	--mattis-shadow-sm: 0 6px 18px rgba(16, 22, 34, 0.08);
	--mattis-shadow-md: 0 12px 32px rgba(16, 22, 34, 0.12);
	--mattis-shadow-lg: 0 18px 48px rgba(16, 22, 34, 0.14);
	--mattis-shadow-xl: 0 28px 64px rgba(16, 22, 34, 0.16);
}

/* ==========================================================================
   Typography - DM Sans Global
   ========================================================================== */

body,
html {
	font-family: var(--mattis-font-family) !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Aplicar DM Sans a todos los elementos de Elementor */
.elementor *,
.elementor-widget-container *,
.elementor-element * {
	font-family: var(--mattis-font-family);
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

.mattis-widget {
	font-family: var(--mattis-font-family);
	font-size: var(--mattis-font-size-base);
	line-height: var(--mattis-line-height-base);
}

[type='button']:focus,
[type='button']:hover,
[type='submit']:focus,
[type='submit']:hover,
button:focus,
button:hover {
	background: none !important;
	outline: none !important;
	color: var(--mattis-primary-active) !important;
}

input[type='date'],
input[type='email'],
input[type='number'],
input[type='password'],
input[type='tel'],
input[type='text'],
input[type='url'],
select,
textarea {
	border: none !important;
}

input[type='date']:focus,
input[type='email']:focus,
input[type='number']:focus,
input[type='password']:focus,
input[type='search']:focus,
input[type='tel']:focus,
input[type='text']:focus,
input[type='url']:focus,
select:focus,
textarea:focus {
	outline: none !important;
	border: none !important;
}

/* ==========================================================================
   Button Component
   ========================================================================== */

.mattis-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 0.85rem 1.85rem;
	background: var(--mattis-primary);
	border: none;
	border-radius: 999px;
	font-family: var(--mattis-font-family);
	font-weight: 600;
	font-size: 15px;
	line-height: 1;
	letter-spacing: 0.02em;
	color: var(--mattis-white);
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease,
		color 0.25s ease;
	position: relative;
	overflow: hidden;
	opacity: 1;
	box-sizing: border-box;
	box-shadow: var(--mattis-shadow-sm);
}

.mattis-button:hover {
	transform: translateY(-2px);
	box-shadow: var(--mattis-shadow-md);
	background: var(--mattis-primary-hover);
}

.mattis-button:active {
	transform: translateY(0);
	box-shadow: var(--mattis-shadow-sm);
	background: var(--mattis-primary-active);
}

/* Button Variants */
.mattis-button--primary {
	background: var(--mattis-primary);
	color: var(--mattis-white);
}

.mattis-button--primary:hover {
	background: var(--mattis-primary-hover);
}

.mattis-button--secondary {
	background: var(--mattis-gray-1);
	color: var(--mattis-white);
}

.mattis-button--secondary:hover {
	background: var(--mattis-gray-2);
}

.mattis-button--gradient {
	background: var(--mattis-gradient-1);
	color: var(--mattis-white);
}

.mattis-button--gradient:hover {
	opacity: 0.9;
}

.mattis-button--outline {
	background: transparent;
	border: 1.5px solid var(--mattis-primary);
	color: var(--mattis-primary);
	box-shadow: none;
}

.mattis-button--outline:hover {
	background: var(--mattis-primary);
	color: var(--mattis-white);
	box-shadow: var(--mattis-shadow-sm);
}

/* Button Sizes */
.mattis-button--small {
	min-width: 108px;
	height: 38px;
	padding: 0.65rem 1.5rem;
	font-size: 14px;
}

.mattis-button--large {
	min-width: 160px;
	height: 52px;
	padding: 1rem 2.5rem;
	font-size: 17px;
}

/* ==========================================================================
   Card Component
   ========================================================================== */

.mattis-card {
	background: var(--mattis-surface);
	border-radius: var(--mattis-radius-xl);
	box-shadow: var(--mattis-shadow-sm);
	border: 1px solid var(--mattis-border-soft);
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.mattis-card:hover {
	box-shadow: var(--mattis-shadow-md);
	transform: translateY(-6px);
}

.mattis-card__image {
	width: 100%;
	height: 220px;
	object-fit: cover;
}

.mattis-card__content {
	padding: var(--mattis-space-md);
}

.mattis-card__title {
	font-size: 18px;
	font-weight: 600;
	color: var(--mattis-dark);
	margin-bottom: var(--mattis-space-sm);
}

.mattis-card__description {
	color: var(--mattis-gray-1);
	margin-bottom: var(--mattis-space-md);
}

.mattis-card__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--mattis-space-sm);
	border-top: 1px solid var(--mattis-gray-8);
}

.mattis-card__price {
	font-size: 18px;
	font-weight: 700;
	color: var(--mattis-primary);
}

/* Property Card Specific */
.mattis-property-card {
	position: relative;
}

.mattis-property-card .mattis-card__image {
	border-top-left-radius: var(--mattis-radius-lg);
	border-top-right-radius: var(--mattis-radius-lg);
	display: block;
}

.mattis-property-card__media {
	position: relative;
}

/* Badges sobre la imagen */
.mattis-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	background: rgba(255, 255, 255, 0.9);
	backdrop-filter: blur(2px);
	color: var(--mattis-dark);
	border-radius: 999px;
	padding: 4px 10px;
	font-size: 12px;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.mattis-badge__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	display: inline-block;
}

.mattis-badge--code {
	left: auto;
	right: 44px;
	background: rgba(255, 255, 255, 0.92);
	color: var(--mattis-gray-2);
}

/* Botón de favorito (corazón) */
.mattis-fav {
	position: absolute;
	top: 12px;
	right: 12px;
	transform: translateY(40px); /* debajo del código */
	background: rgba(255, 255, 255, 0.92);
	border: none;
	border-radius: 999px;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: var(--mattis-white);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}
.mattis-fav svg {
	stroke: #ffffff;
}

/* Dots del carrusel */
.mattis-media-dots {
	position: absolute;
	left: 50%;
	bottom: 12px;
	transform: translateX(-50%);
	display: inline-flex;
	gap: 6px;
}
.mattis-media-dots span {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.8);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.08);
}

.mattis-property-card__badge {
	position: absolute;
	top: var(--mattis-space-sm);
	right: var(--mattis-space-sm);
	background: var(--mattis-red);
	color: var(--mattis-white);
	padding: 4px 8px;
	border-radius: var(--mattis-radius-sm);
	font-size: 12px;
	font-weight: 600;
}

.mattis-property-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: var(--mattis-space-sm) 0 0;
	padding-top: 14px;
	border-top: 1px solid var(--mattis-border-soft);
}

.mattis-property-card__feature {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--mattis-gray-2);
	font-size: 13px;
	font-weight: 500;
}

/* Iconos de características en naranja */
.mattis-property-card__feature svg {
	color: var(--mattis-primary);
}

/* ==========================================================================
   Input Component
   ========================================================================== */

.mattis-input {
	width: 100%;
	padding: 12px 16px;
	border: 2px solid var(--mattis-gray-8);
	background: var(--mattis-white);
	font-size: var(--mattis-font-size-base);
	border-radius: var(--mattis-radius-md);
	color: var(--mattis-dark);
	transition: border-color 0.25s ease, background 0.25s ease;
}
.mattis-input:focus {
	outline: none;
	border-color: var(--mattis-primary);
	background: var(--mattis-white);
}
.mattis-input::placeholder {
	color: var(--mattis-gray-4);
}

.mattis-input--search {
	padding-left: 48px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23686867' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cpath d='m21 21-4.35-4.35'%3E%3C/path%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: 16px center;
}

.mattis-select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23686867' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6,9 12,15 18,9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	background: transparent;
}

/* ==========================================================================
   Navbar Component
   ========================================================================== */

/* ==========================================================================
   Navbar Component
   ========================================================================== */

.mattis-navbar {
	background: var(--mattis-white);
	color: var(--mattis-dark);
	z-index: 1000;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
	position: relative;
	width: 100%;
}

.mattis-navbar__container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 19px 55px;
	max-width: 1440px;
	height: 123px;
	margin: 0 auto;
	border-bottom-right-radius: 20px;
	border-bottom-left-radius: 20px;
	opacity: 1;
	box-sizing: border-box;
}

.mattis-navbar__logo {
	display: flex;
	align-items: center;
	width: 236px;
	height: 85px;
	flex-shrink: 0;
	opacity: 1;
	margin-right: 48px;
}

.mattis-navbar__logo-image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left center;
}

.mattis-navbar__logo-text {
	font-size: 24px;
	font-weight: 700;
	color: var(--mattis-primary);
	text-decoration: none;
}

.mattis-navbar__menu-wrapper {
	flex: 1;
	display: flex;
	justify-content: center;
	margin: 0 32px;
}

.mattis-navbar__menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 32px;
	align-items: center;
}

.mattis-navbar__item {
	position: relative;
}

.mattis-navbar__link {
	color: var(--mattis-dark);
	text-decoration: none;
	font-weight: 500;
	font-size: 16px;
	line-height: 1.2;
	transition: color 0.3s ease;
	position: relative;
	padding: 8px 0;
	min-width: 74px;
	height: 23px;
	opacity: 1;
	transform: rotate(0deg);
}

.mattis-navbar__link:hover,
.mattis-navbar__link--active {
	color: #db7e2b;
}

.mattis-navbar__link:hover::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: #db7e2b;
}

/* User Actions */
.mattis-navbar__actions {
	display: flex;
	align-items: center;
	gap: 24px;
	flex-shrink: 0;
	margin-left: auto;
}

/* Configuración 1 y 2: Horizontal (por defecto) */
.mattis-navbar__actions:not(.mattis-navbar__actions--stacked) {
	flex-direction: row;
}

/* Configuración 3: Stacked (apilado) */
.mattis-navbar__actions--stacked {
	flex-direction: column;
	align-items: flex-end;
	gap: 8px;
}

.mattis-navbar__actions--stacked .mattis-navbar__actions-group {
	display: flex;
	gap: 24px;
	align-items: center;
}

.mattis-navbar__action {
	display: flex;
	align-items: center;
}

/* Ocultar acciones cuando show = no */
.mattis-navbar__action:empty {
	display: none;
}

.mattis-navbar__action-link {
	display: flex;
	align-items: center;
	gap: 8px;
	color: #2c2c2c;
	text-decoration: none;
	font-weight: 500;
	font-size: 14px;
	line-height: 1.4;
	transition: color 0.3s ease;
	white-space: nowrap;
	padding: 6px 0;
}

.mattis-navbar__action-link:hover {
	color: #db7e2b;
}

/* SVG icon sizes for actions */
.mattis-navbar__action-icon,
.mattis-navbar__action .mattis-icon {
	width: 20px;
	height: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: currentColor;
	flex-shrink: 0;
}

.mattis-navbar__cta {
	flex-shrink: 0;
}

.mattis-navbar__cta .mattis-button {
	/* Botón de Pagos - Especificaciones del diseño */
	min-width: 100px;
	height: 44px;
	padding: 10px 24px;
	font-size: 16px;
	font-weight: 600;
	background-color: #db7e2b;
	border: none;
	border-radius: 200px;
	color: var(--mattis-white);
	text-decoration: none;
	transition: all 0.3s ease;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	box-sizing: border-box;
	cursor: pointer;
}

.mattis-navbar__cta .mattis-button:hover {
	background-color: #c86d23;
	transform: scale(0.98);
}

.mattis-navbar__toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 32px;
	height: 32px;
}

.mattis-navbar__toggle span {
	display: block;
	width: 20px;
	height: 2px;
	background: var(--mattis-dark);
	margin: 3px 0;
	transition: all 0.3s ease;
	transform-origin: center;
}

.mattis-navbar__toggle.is-active span:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}

.mattis-navbar__toggle.is-active span:nth-child(2) {
	opacity: 0;
}

.mattis-navbar__toggle.is-active span:nth-child(3) {
	transform: translateY(-8px) rotate(-45deg);
}

/* Navbar scroll effect */
.mattis-navbar.scrolled {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
	backdrop-filter: blur(10px);
}

/* Navbar when menu is open */
.mattis-navbar.menu-open {
	position: relative;
	z-index: 1001;
}

/* Mobile Navigation */
@media (max-width: 768px) {
	.mattis-navbar__container {
		padding: 12px 16px;
		height: auto;
		flex-wrap: wrap;
	}

	.mattis-navbar__logo {
		width: 160px;
		height: 58px;
		margin-right: 16px;
	}

	.mattis-navbar__menu-wrapper {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--mattis-white);
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
		border-radius: 0 0 12px 12px;
		transform: translateY(-100%);
		opacity: 0;
		visibility: hidden;
		transition: all 0.3s ease;
		z-index: 999;
		margin: 0;
	}

	.mattis-navbar__menu-wrapper--open {
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
	}

	.mattis-navbar__menu {
		flex-direction: column;
		padding: 16px;
		gap: 16px;
		align-items: flex-start;
	}

	.mattis-navbar__link {
		font-size: 16px;
		padding: 12px 0;
		width: 100%;
	}

	.mattis-navbar__actions {
		gap: 12px;
	}

	.mattis-navbar__actions--stacked {
		gap: 4px;
	}

	.mattis-navbar__actions--stacked .mattis-navbar__actions-group {
		gap: 12px;
	}

	.mattis-navbar__action-link {
		font-size: 13px;
		gap: 6px;
	}

	.mattis-navbar__cta .mattis-button {
		min-width: 80px;
		height: 38px;
		padding: 8px 18px;
		font-size: 14px;
	}

	.mattis-navbar__toggle {
		display: flex;
		order: 4;
		margin-left: 16px;
	}
}

/* ==========================================================================
   Hero Section Component
   ========================================================================== */

.mattis-hero {
	position: relative;
	min-height: 560px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center;
	color: var(--mattis-white);
	padding: clamp(80px, 12vw, 140px) 0 clamp(48px, 9vw, 120px);
}

.mattis-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		90deg,
		rgba(13, 14, 20, 0.78) 0%,
		rgba(13, 14, 20, 0.52) 40%,
		rgba(13, 14, 20, 0.18) 68%,
		rgba(13, 14, 20, 0) 100%
	);
	z-index: 1;
}

.mattis-hero__content {
	position: relative;
	z-index: 2;
	width: min(560px, 92vw);
	margin-left: clamp(24px, 8vw, 120px);
	margin-right: auto;
	display: flex;
	flex-direction: column;
	gap: 24px;
	text-align: left;
}

.mattis-hero__title {
	font-size: clamp(42px, 5.6vw, 64px);
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: -0.015em;
	margin: 0;
}

.mattis-hero__subtitle {
	font-size: clamp(18px, 2.4vw, 22px);
	color: rgba(255, 255, 255, 0.86);
	margin: 0;
	max-width: 520px;
}

.mattis-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	justify-content: flex-start;
}

@media (max-width: 960px) {
	.mattis-hero {
		min-height: 480px;
	}
	.mattis-hero__content {
		margin-left: clamp(20px, 6vw, 80px);
	}
}

@media (max-width: 640px) {
	.mattis-hero {
		min-height: 420px;
		padding: clamp(56px, 16vw, 100px) 0 68px;
	}
	.mattis-hero__content {
		margin-left: clamp(16px, 5vw, 36px);
	}
}

/* ==========================================================================
   Search Component
   ========================================================================== */

.mattis-search {
	background: var(--mattis-white);
	border-radius: var(--mattis-radius-lg);
	padding: var(--mattis-space-lg);
	box-shadow: var(--mattis-shadow-md);
	margin-top: calc(var(--mattis-space-xl) * -1);
	position: relative;
	z-index: 10;
}

.mattis-search__form {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--mattis-space-sm);
	align-items: end;
}

.mattis-search__field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.mattis-search__label {
	font-weight: 600;
	color: var(--mattis-dark);
	font-size: 14px;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.mattis-text-center {
	text-align: center;
}
.mattis-text-left {
	text-align: left;
}
.mattis-text-right {
	text-align: right;
}

.mattis-mb-xs {
	margin-bottom: var(--mattis-space-xs);
}
.mattis-mb-sm {
	margin-bottom: var(--mattis-space-sm);
}
.mattis-mb-md {
	margin-bottom: var(--mattis-space-md);
}
.mattis-mb-lg {
	margin-bottom: var(--mattis-space-lg);
}

.mattis-mt-xs {
	margin-top: var(--mattis-space-xs);
}
.mattis-mt-sm {
	margin-top: var(--mattis-space-sm);
}
.mattis-mt-md {
	margin-top: var(--mattis-space-md);
}
.mattis-mt-lg {
	margin-top: var(--mattis-space-lg);
}

.mattis-p-xs {
	padding: var(--mattis-space-xs);
}
.mattis-p-sm {
	padding: var(--mattis-space-sm);
}
.mattis-p-md {
	padding: var(--mattis-space-md);
}
.mattis-p-lg {
	padding: var(--mattis-space-lg);
}

/* Responsive Grid */
.mattis-grid {
	display: grid;
	gap: var(--mattis-space-md);
}

.mattis-grid--2 {
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.mattis-grid--3 {
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.mattis-grid--4 {
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Container */
.mattis-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--mattis-space-md);
}

/* ==========================================================================
   Promo Card (Hero y Lista)
   ========================================================================== */
.mattis-promo-card {
	position: relative;
	background-size: cover;
	background-position: center;
	border-radius: 24px;
	min-height: 300px;
	overflow: hidden;
}
.mattis-promo-card--hero .mattis-promo-card__overlay {
	position: absolute;
	left: 32px;
	bottom: 32px;
	background: #1d1d1d;
	color: #fff;
	border-radius: 24px;
	padding: 24px;
	max-width: 360px;
	box-shadow: var(--mattis-shadow-sm);
}
.mattis-promo-card__over-title {
	color: var(--mattis-gold);
	font-weight: 500;
	margin-bottom: 8px;
}
.mattis-promo-card__title {
	font-size: 24px;
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 16px;
}
.mattis-promo-card--list {
	padding: 24px;
	border-radius: 16px;
}
.mattis-promo-card--list .mattis-promo-card__list {
	background: transparent;
	border-radius: 16px;
	padding: 16px;
	max-width: 280px;
}
.mattis-promo-card__list-title {
	font-weight: 700;
	color: var(--mattis-dark);
	margin-bottom: 12px;
}
.mattis-promo-card__list ul {
	margin: 0;
	padding-left: 20px;
}
.mattis-promo-card__list li {
	margin: 0;
	color: var(--mattis-gray-2);
}

/* ==========================================================================
   Elementor Global Overrides (Buttons)
   Estas reglas se aplican a los botones nativos de Elementor para unificar
   el estilo al instalar el plugin.
   Especificación solicitada:
   - background: #DB7E2B
   - padding: 8px 20px
   - gap: 10px (icono-texto)
   - border-radius: 200px
   - angle: 0deg (no aplica salvo gradientes)
   ========================================================================== */
.elementor a.elementor-button,
.elementor .elementor-button {
	background-color: #db7e2b;
	padding: 8px 20px;
	border-radius: 200px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	box-sizing: border-box;
	color: #fff;
}

/* Wrapper interno de Elementor para icono + texto */
.elementor .elementor-button .elementor-button-content-wrapper {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

/* Mantener color del texto en hover/focus/visited */
.elementor .elementor-button:hover,
.elementor .elementor-button:focus,
.elementor .elementor-button:visited {
	color: #fff;
}

/* Animations */
@keyframes mattis-fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.mattis-animate-fadeInUp {
	animation: mattis-fadeInUp 0.6s ease-out;
}

/* Dark Theme Support */
@media (prefers-color-scheme: dark) {
	:root {
		--mattis-white: #1a1a1a;
		--mattis-dark: #ffffff;
		--mattis-light: #2a2a2a;
	}
}
