/* =====================================================================
   HEXA ELEMENTOR — Sistema de diseño
   Reproduce la landing de Hexa Asesoría Estratégica (export de Figma).
   Las clases hexa-* se aplican a contenedores/widgets de Elementor vía
   "Clases CSS"; los selectores van scopeados por sección para ganar
   especificidad sobre los estilos base de Elementor sin abusar de !important.
   ===================================================================== */

:root {
	--hexa-primary: #008fe1;   /* Cerulean  */
	--hexa-deep:    #004e95;   /* Congress Blue */
	--hexa-light:   #61c3f9;   /* Malibu */
	--hexa-dark:    #1c2229;   /* Ebony Clay */
	--hexa-azure-11:#151b21;
	--hexa-azure-20:#2b343d;
	--hexa-outer:   #2e3339;   /* Outer Space */
	--hexa-bg:      #fafcfe;   /* Polar */
	--hexa-badge:   #0d4c8a;
	--hexa-white:   #ffffff;

	--hexa-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
	--hexa-maxw: 1280px;
	--hexa-radius: 24px;
	--hexa-radius-card: 20px;
	--hexa-shadow-soft: 0 8px 30px -10px rgba(0, 78, 149, .18);
	--hexa-shadow-lift: 0 20px 60px -20px rgba(0, 78, 149, .35);
	--hexa-grad-hero: linear-gradient(135deg, #004e95 0%, #008fe1 60%, #61c3f9 100%);
	--hexa-grad-dark: linear-gradient(160deg, #151b21 0%, #2b343d 100%);
	--hexa-grad-footer: linear-gradient(180deg, #151b21 0%, #1c2229 100%);
}

/* ---------- Base ---------- */
.hexa-body {
	font-family: var(--hexa-font);
	color: var(--hexa-dark);
	background: var(--hexa-bg);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.hexa-body img { max-width: 100%; height: auto; display: block; }
.hexa-body a { color: var(--hexa-primary); text-decoration: none; }

.hexa-container {
	width: 100%;
	max-width: var(--hexa-maxw);
	margin-inline: auto;
	padding-inline: 24px;
}

/* Compensa la cabecera fija al saltar a anclas (#planes, #contacto…) por URL directa. */
html { scroll-padding-top: 96px; }

.hexa-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
}
.hexa-skip-link:focus {
	left: 16px;
	top: 16px;
	z-index: 1001;
	width: auto;
	height: auto;
	clip: auto;
	background: #fff;
	color: var(--hexa-deep);
	padding: 10px 18px;
	border-radius: 10px;
	box-shadow: var(--hexa-shadow-lift);
}
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	white-space: nowrap;
}

/* =====================================================================
   HEADER
   ===================================================================== */
.hexa-header {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 1000;
	padding-block: 22px;
	transition: background .3s ease, padding .3s ease, box-shadow .3s ease, backdrop-filter .3s ease;
}
.hexa-header.is-scrolled,
.hexa-header--solid {
	background: rgba(8, 22, 38, .92);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	box-shadow: 0 1px 0 rgba(255, 255, 255, .06);
	padding-block: 12px;
}
.hexa-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.hexa-header__logo { display: inline-flex; align-items: center; }
.hexa-header__logo a,
.hexa-header__logo .custom-logo-link { display: inline-flex; align-items: center; }
.hexa-header__logo img { height: 58px; width: auto; }
.hexa-header.is-scrolled .hexa-header__logo img { height: 46px; }

.hexa-nav { display: flex; align-items: center; gap: 8px; }
.hexa-nav__menu {
	display: flex;
	align-items: center;
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.hexa-nav__menu a {
	color: rgba(255, 255, 255, .82);
	font-size: 15px;
	font-weight: 500;
	letter-spacing: .2px;
	transition: color .2s ease;
}
.hexa-nav__menu a:hover { color: #fff; }
.hexa-nav__menu .menu-item--cta a {
	display: inline-flex;
	align-items: center;
	padding: 11px 26px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .12);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .25);
	color: #fff;
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
}
.hexa-nav__menu .menu-item--cta a:hover { background: rgba(255, 255, 255, .2); }

.hexa-nav__toggle {
	display: none;
	width: 42px; height: 42px;
	border: 0; border-radius: 12px;
	background: rgba(255, 255, 255, .12);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .25);
	cursor: pointer;
	position: relative;
}
.hexa-nav__toggle-bar,
.hexa-nav__toggle-bar::before,
.hexa-nav__toggle-bar::after {
	content: "";
	position: absolute;
	left: 50%; top: 50%;
	width: 18px; height: 2px;
	background: #fff;
	transform: translate(-50%, -50%);
	transition: transform .25s ease, opacity .25s ease;
}
.hexa-nav__toggle-bar::before { transform: translate(-50%, -7px); }
.hexa-nav__toggle-bar::after  { transform: translate(-50%, 5px); }

/* =====================================================================
   HELPERS DE SECCIÓN (contenedores Elementor)
   content_width:full + padding/gap 0 en Elementor; el layout vive aquí.
   ===================================================================== */
.hexa-sec { width: 100%; position: relative; overflow: hidden; }
.hexa-sec .hexa-wrap,
.e-con.hexa-wrap {
	width: 100%;
	max-width: var(--hexa-maxw);
	margin-inline: auto;
	padding-inline: 24px;
	position: relative;
	z-index: 2;
}

/* Tipografía compartida (scopeada para vencer a Elementor) */
.hexa-sec .hexa-eyebrow .elementor-heading-title,
.hexa-sec .hexa-eyebrow {
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--hexa-primary);
	margin: 0;
}
.hexa-sec .hexa-eyebrow--light .elementor-heading-title { color: var(--hexa-light); }

.hexa-sec .hexa-h2 .elementor-heading-title,
.hexa-sec .hexa-h2 {
	font-size: clamp(2rem, 1.2rem + 2.6vw, 2.95rem);
	line-height: 1.04;
	font-weight: 700;
	letter-spacing: -1.2px;
	color: var(--hexa-dark);
	margin: 0;
}
.hexa-sec .hexa-h2--white .elementor-heading-title { color: #fff; }

.hexa-sec .hexa-sub .elementor-widget-container,
.hexa-sec .hexa-sub p,
.hexa-sec .hexa-sub {
	font-size: clamp(1rem, .96rem + .2vw, 1.0625rem);
	line-height: 1.65;
	color: rgba(46, 51, 57, .7);
	margin: 0;
}
.hexa-sec .hexa-sub--light p,
.hexa-sec .hexa-sub--light .elementor-widget-container { color: rgba(255, 255, 255, .7); }

/* Cabecera de sección (eyebrow + h2 + sub) con separaciones */
.hexa-sec .hexa-head { display: flex; flex-direction: column; gap: 19px; max-width: 672px; }
.hexa-sec .hexa-head--center { margin-inline: auto; align-items: center; text-align: center; }

/* Botones genéricos (widget button de Elementor + enlaces propios) */
.hexa-btn-light .elementor-button,
a.hexa-btn-light {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #fff;
	color: var(--hexa-deep);
	font-family: var(--hexa-font);
	font-weight: 700;
	font-size: 14px;
	line-height: 20px;
	padding: 14px 28px;
	border-radius: 999px;
	border: 0;
	box-shadow: var(--hexa-shadow-lift);
	transition: transform .2s ease, box-shadow .2s ease;
}
.hexa-btn-light .elementor-button:hover,
a.hexa-btn-light:hover { transform: translateY(-2px); box-shadow: 0 26px 70px -22px rgba(0, 78, 149, .5); color: var(--hexa-deep); }

.hexa-btn-ghost .elementor-button {
	display: inline-flex;
	align-items: center;
	background: transparent;
	color: #fff;
	font-family: var(--hexa-font);
	font-weight: 700;
	font-size: 14px;
	line-height: 20px;
	padding: 14px 29px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .3);
	transition: background .2s ease, border-color .2s ease;
}
.hexa-btn-ghost .elementor-button:hover { background: rgba(255, 255, 255, .1); border-color: rgba(255, 255, 255, .55); }

/* Reset del wrapper del botón de Elementor para alinear a la izquierda */
.hexa-btn-light .elementor-button-wrapper,
.hexa-btn-ghost .elementor-button-wrapper { display: inline-block; }

/* =====================================================================
   HERO  (#top)
   ===================================================================== */
.hexa-sec.hexa-hero {
	background: var(--hexa-grad-hero);
	color: #fff;
	padding-top: clamp(8rem, 6rem + 9vw, 11rem);
	padding-bottom: clamp(4rem, 2.5rem + 7vw, 9rem);
}
.hexa-hero::before { /* textura panal — cubre todo el hero */
	content: "";
	position: absolute;
	inset: 0;
	background: url("../images/honeycomb.jpg") center / cover no-repeat;
	opacity: .08;
	pointer-events: none;
	z-index: 0;
}
.hexa-hero::after { /* orbe difuso superior derecho */
	content: "";
	position: absolute;
	top: -128px; right: -128px;
	width: 500px; height: 500px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .1);
	filter: blur(32px);
	pointer-events: none;
	z-index: 0;
}
.hexa-hero .hexa-hero-grid,
.e-con.hexa-hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
	gap: 48px;
	align-items: center;
}
.hexa-hero .hexa-hero-left,
.e-con.hexa-hero-left {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 23px;
}
.hexa-hero .hexa-hero-right,
.e-con.hexa-hero-right { display: block; }

/* Pill / badge superior */
.hexa-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 16px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .1);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .2);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	font-size: 12px;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, .9);
}
.hexa-pill__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--hexa-light); }

/* H1 */
.hexa-hero .hexa-h1 .elementor-heading-title,
.hexa-hero .hexa-h1 {
	font-size: clamp(2.6rem, 1.2rem + 5vw, 4.35rem);
	line-height: 1.07;
	font-weight: 700;
	letter-spacing: -1.8px;
	color: #fff;
	margin: 0;
}
.hexa-hero .hexa-h1 .hexa-accent { color: var(--hexa-light); }

/* Lead */
.hexa-hero .hexa-lead .elementor-widget-container,
.hexa-hero .hexa-lead p,
.hexa-hero .hexa-lead {
	max-width: 576px;
	font-size: clamp(1rem, .96rem + .3vw, 1.0625rem);
	line-height: 1.72;
	color: rgba(255, 255, 255, .85);
	margin: 0;
}

/* Acciones */
.hexa-hero .hexa-actions,
.hexa-contact-card .hexa-actions,
.e-con.hexa-actions {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
	margin-top: 8px;
}

/* Estadísticas */
.hexa-stats {
	display: flex;
	gap: 24px;
	max-width: 512px;
	margin-top: 16px;
	padding-top: 33px;
	border-top: 1px solid rgba(255, 255, 255, .15);
}
.hexa-stat { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.hexa-stat__label {
	font-size: 12px;
	letter-spacing: .6px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, .6);
}
.hexa-stat__value { font-size: 22px; font-weight: 700; line-height: 32px; color: #fff; }

/* Tarjeta visual (logo + insignias flotantes) */
.hexa-card-visual {
	position: relative;
	max-width: 448px;
	margin-inline: auto;
}
.hexa-card-visual__panel {
	position: relative;
	background: #fff;
	border-radius: var(--hexa-radius);
	padding: 59px 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .4), var(--hexa-shadow-lift);
}
.hexa-card-visual__panel img { width: 100%; max-width: 368px; height: auto; }
.hexa-badge-float {
	position: absolute;
	border-radius: 20px;
	padding: 16px 20px;
	box-shadow: var(--hexa-shadow-lift);
	z-index: 2;
}
.hexa-badge-float--rule { left: -24px; bottom: -24px; background: var(--hexa-badge); }
.hexa-badge-float--sii  { right: -18px; top: -16px; background: var(--hexa-dark); }
.hexa-badge-float__top {
	font-size: 12px;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, .7);
	line-height: 16px;
}
.hexa-badge-float--rule .hexa-badge-float__big { font-size: 30px; font-weight: 700; line-height: 36px; color: #fff; }
.hexa-badge-float--sii .hexa-badge-float__big { font-size: 14px; font-weight: 700; line-height: 20px; color: #fff; }

/* =====================================================================
   PILARES  (#pilares)
   ===================================================================== */
.hexa-sec.hexa-pilares { background: var(--hexa-bg); padding-block: clamp(4.5rem, 3rem + 8vw, 8rem); }
.hexa-pilares .hexa-wrap { display: flex; flex-direction: column; gap: 64px; }
.hexa-pilares .hexa-cards,
.e-con.hexa-cards {
	display: flex;
	flex-direction: row;
	gap: 24px;
	align-items: stretch;
	justify-content: center;
}
.hexa-pilares .hexa-card,
.e-con.hexa-card {
	position: relative;
	flex: 1 1 0;
	min-width: 0;
	background: #fff;
	border: 1px solid rgba(0, 143, 225, .1);
	border-radius: var(--hexa-radius-card);
	box-shadow: var(--hexa-shadow-soft);
	padding: 33px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: transform .25s ease, box-shadow .25s ease;
}
.hexa-pilares .hexa-card:hover { transform: translateY(-4px); box-shadow: 0 18px 50px -16px rgba(0, 78, 149, .28); }
.hexa-pilares .hexa-card::after { /* ícono hexágono decorativo */
	content: "";
	position: absolute;
	top: 24px; right: 24px;
	width: 80px; height: 80px;
	background: url("../images/icon-hex.png") center / contain no-repeat;
	opacity: .1;
	pointer-events: none;
}
.hexa-pilares .hexa-card-num .elementor-heading-title,
.hexa-pilares .hexa-card-num {
	font-size: 14px; font-weight: 700; color: var(--hexa-primary); margin: 0;
}
.hexa-pilares .hexa-card-title .elementor-heading-title,
.hexa-pilares .hexa-card-title {
	font-size: 1.45rem; line-height: 1.35; font-weight: 700; color: var(--hexa-dark); margin: 0;
}
.hexa-pilares .hexa-card-text .elementor-widget-container,
.hexa-pilares .hexa-card-text p,
.hexa-pilares .hexa-card-text {
	font-size: .95rem; line-height: 1.7; color: rgba(46, 51, 57, .75); margin: 0;
}

/* =====================================================================
   PLANES  (#planes)
   ===================================================================== */
.hexa-sec.hexa-planes { background: var(--hexa-grad-dark); color: #fff; padding-block: clamp(4.5rem, 3rem + 8vw, 8rem); }
.hexa-planes::before {
	content: "";
	position: absolute;
	inset: 0;
	background: url("../images/honeycomb.jpg") center / cover no-repeat;
	opacity: .05;
	pointer-events: none;
	z-index: 0;
}
.hexa-planes .hexa-wrap { display: flex; flex-direction: column; gap: 40px; align-items: center; }
.hexa-planes .hexa-plans,
.e-con.hexa-plans {
	display: flex;
	flex-direction: row;
	gap: 20px;
	align-items: center;
	justify-content: center;
	width: 100%;
}
.hexa-plan,
.e-con.hexa-plan {
	position: relative;
	flex: 1 1 0;
	min-width: 0;
	border-radius: var(--hexa-radius-card);
	padding: 32px;
	display: flex;
	flex-direction: column;
	align-items: stretch;
}
/* Planes glass (laterales) */
.hexa-plan--glass {
	background: rgba(255, 255, 255, .05);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .1);
}
/* Plan destacado (centro) */
.hexa-plan--featured {
	background: #fff;
	color: var(--hexa-dark);
	box-shadow: inset 0 0 0 2px var(--hexa-light), var(--hexa-shadow-lift);
	margin-block: -14px;
	padding-block: 46px 32px;
	z-index: 3;
}

.hexa-plan-name .elementor-heading-title,
.hexa-plan-name { font-size: 1.22rem; font-weight: 700; line-height: 1.4; color: #fff; margin: 0; }
.hexa-plan--featured .hexa-plan-name .elementor-heading-title { color: var(--hexa-dark); }

.hexa-plan-desc .elementor-widget-container,
.hexa-plan-desc p,
.hexa-plan-desc { font-size: .83rem; line-height: 1.45; color: rgba(255, 255, 255, .6); margin: 4px 0 0; }
.hexa-plan--featured .hexa-plan-desc .elementor-widget-container,
.hexa-plan--featured .hexa-plan-desc p { color: rgba(46, 51, 57, .6); }

.hexa-price { display: flex; align-items: baseline; gap: 4px; margin-top: 24px; }
.hexa-price__amount { font-size: 1.95rem; font-weight: 700; line-height: 1.25; color: #fff; }
.hexa-plan--featured .hexa-price__amount { color: var(--hexa-dark); }
.hexa-price__per { font-size: 14px; color: rgba(255, 255, 255, .6); }
.hexa-plan--featured .hexa-price__per { color: rgba(46, 51, 57, .6); }

/* Lista de features (widget icon-list) */
.hexa-plan-list { margin-top: 32px; flex: 1; min-width: 0; }
.hexa-plan-list .elementor-icon-list-items { display: flex; flex-direction: column; gap: 12px; padding: 0; margin: 0; }
.hexa-plan-list .elementor-icon-list-item { padding: 0; align-items: flex-start; min-width: 0; }
.hexa-plan-list .elementor-icon-list-icon { padding-top: 2px; flex-shrink: 0; }
.hexa-plan-list .elementor-icon-list-icon svg,
.hexa-plan-list .elementor-icon-list-icon i {
	width: 18px; height: 18px; font-size: 16px; color: var(--hexa-light); fill: var(--hexa-light);
}
.hexa-plan-list .elementor-icon-list-text { font-size: .83rem; line-height: 1.45; color: rgba(255, 255, 255, .85); min-width: 0; overflow-wrap: break-word; }
.hexa-plan--featured .hexa-plan-list .elementor-icon-list-icon svg,
.hexa-plan--featured .hexa-plan-list .elementor-icon-list-icon i { color: var(--hexa-primary); fill: var(--hexa-primary); }
.hexa-plan--featured .hexa-plan-list .elementor-icon-list-text { color: var(--hexa-dark); }

/* Botón del plan */
.hexa-plan-btn { margin-top: 32px; }
.hexa-plan-btn .elementor-button {
	display: flex; justify-content: center; width: 100%;
	font-family: var(--hexa-font); font-weight: 700; font-size: 14px; line-height: 20px;
	padding: 13px 24px; border-radius: 999px;
	background: transparent; color: #fff; border: 1px solid rgba(255, 255, 255, .25);
	transition: background .2s ease, border-color .2s ease;
}
.hexa-plan-btn .elementor-button:hover { background: rgba(255, 255, 255, .12); border-color: rgba(255, 255, 255, .5); }
.hexa-plan-btn .elementor-button-wrapper { width: 100%; }
.hexa-plan--featured .hexa-plan-btn .elementor-button {
	background: var(--hexa-primary); color: #fff; border-color: transparent;
}
.hexa-plan--featured .hexa-plan-btn .elementor-button:hover { background: #0079c2; }

/* Cinta "Más Elegido" */
.hexa-ribbon {
	position: absolute;
	top: -12px; left: 50%; transform: translateX(-50%);
	background: var(--hexa-primary);
	color: #fff;
	font-size: 12px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
	padding: 4px 16px; border-radius: 999px; white-space: nowrap;
	box-shadow: 0 10px 24px -10px rgba(0, 143, 225, .8);
}

.hexa-foot-note .elementor-widget-container,
.hexa-foot-note { font-size: 13px; color: rgba(255, 255, 255, .5); text-align: center; margin: 0; }

/* Robustez del layout de planes.
   El contenido de cada tarjeta DEBE apilarse en vertical (nombre, precio,
   features, botón). Estos selectores ganan especificidad sobre el CSS por
   página que genera Elementor (`.elementor-element-XXXX.e-con`) para que la
   dirección "columna" no se pierda nunca; sin esto, si el contenedor cae a su
   dirección por defecto (fila), la lista de características se desborda y se
   recorta en móvil. */
.hexa-planes .hexa-plan,
.hexa-planes .e-con.hexa-plan { flex-direction: column; min-width: 0; }

/* =====================================================================
   CONTACTO  (#contacto)
   ===================================================================== */
.hexa-sec.hexa-contacto { background: var(--hexa-bg); padding-block: clamp(4.5rem, 3rem + 8vw, 8rem); }
.hexa-contacto .hexa-wrap { max-width: 1024px; }
.hexa-contact-card,
.e-con.hexa-contact-card {
	position: relative;
	overflow: hidden;
	background: var(--hexa-dark);
	border-radius: var(--hexa-radius);
	padding: clamp(2.25rem, 1.5rem + 3vw, 4rem);
	box-shadow: var(--hexa-shadow-lift);
	display: flex;
	flex-direction: column;
	gap: 16px;
	align-items: flex-start;
}
.hexa-contact-card::before {
	content: "";
	position: absolute;
	top: -80px; right: -80px;
	width: 320px; height: 320px;
	border-radius: 50%;
	background: rgba(0, 143, 225, .3);
	filter: blur(32px);
	pointer-events: none;
}
.hexa-contact-card::after {
	content: "";
	position: absolute;
	bottom: -80px; left: -80px;
	width: 320px; height: 320px;
	border-radius: 50%;
	background: rgba(97, 195, 249, .2);
	filter: blur(32px);
	pointer-events: none;
}
.hexa-contacto .hexa-contact-card > * { position: relative; z-index: 2; }
.hexa-contacto .hexa-lead-d .elementor-widget-container,
.hexa-contacto .hexa-lead-d p,
.hexa-contacto .hexa-lead-d {
	max-width: 576px; font-size: 1.0625rem; line-height: 1.65; color: rgba(255, 255, 255, .75); margin: 0;
}
.hexa-mail {
	display: inline-flex;
	align-items: center;
	font-size: 14px;
	color: rgba(255, 255, 255, .8);
}
.hexa-mail:hover { color: #fff; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.hexa-footer {
	position: relative;
	overflow: hidden;
	background: var(--hexa-grad-footer);
	color: rgba(255, 255, 255, .6);
	padding-block: 56px;
}
.hexa-footer::before {
	content: "";
	position: absolute;
	inset: 0;
	background: url("../images/honeycomb.jpg") center / cover no-repeat;
	opacity: .04;
	pointer-events: none;
}
.hexa-footer__glow {
	position: absolute;
	width: 320px; height: 320px;
	border-radius: 50%;
	filter: blur(40px);
	pointer-events: none;
}
.hexa-footer__glow--a { top: -128px; right: -128px; background: rgba(0, 143, 225, .10); }
.hexa-footer__glow--b { bottom: -128px; left: -128px; background: rgba(0, 143, 225, .07); }
.hexa-footer__inner { position: relative; z-index: 2; }
.hexa-footer__logo { display: inline-flex; }
.hexa-footer__logo img { height: 48px; width: auto; }
.hexa-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 40px;
	padding-top: 24px;
	border-top: 1px solid rgba(255, 255, 255, .08);
}
.hexa-footer__copy { font-size: 13px; }
.hexa-footer__loc { font-size: 12px; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .5); }
.hexa-footer__menu { display: flex; gap: 20px; list-style: none; margin: 24px 0 0; padding: 0; }
.hexa-footer__menu a { color: rgba(255, 255, 255, .7); font-size: 14px; }

/* =====================================================================
   ARTÍCULOS / BLOG (páginas no construidas con Elementor)
   ===================================================================== */
.hexa-page--builder { padding: 0; }
.hexa-article { padding-block: clamp(7rem, 5rem + 6vw, 9rem) clamp(3rem, 2rem + 3vw, 5rem); }
.hexa-article__title { font-size: clamp(2rem, 1.4rem + 2vw, 2.6rem); font-weight: 700; letter-spacing: -.5px; color: var(--hexa-dark); }
.hexa-article__content { font-size: 1.05rem; line-height: 1.75; }
.hexa-archive__item { padding-block: 24px; border-bottom: 1px solid rgba(0, 78, 149, .08); }
.hexa-archive__title a { color: var(--hexa-dark); }
.hexa-404 { text-align: center; }
.hexa-404 .hexa-article__title { font-size: clamp(3rem, 2rem + 6vw, 6rem); color: var(--hexa-primary); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1024px) {
	.hexa-hero .hexa-hero-grid,
	.e-con.hexa-hero-grid { grid-template-columns: 1fr; gap: 56px; }
	.hexa-hero .hexa-hero-right { order: 2; }
	.hexa-card-visual { margin-inline: 0; }

	.hexa-pilares .hexa-cards,
	.hexa-planes .hexa-plans { flex-wrap: wrap; }
	.hexa-pilares .hexa-card,
	.hexa-plan { flex: 1 1 280px; }
	.hexa-plan--featured { margin-block: 0; }
}

@media (max-width: 860px) {
	.hexa-nav__toggle { display: inline-flex; }
	.hexa-nav__menu {
		position: fixed;
		inset: 76px 16px auto 16px;
		flex-direction: column;
		align-items: stretch;
		gap: 4px;
		padding: 12px;
		border-radius: 18px;
		background: rgba(8, 22, 38, .92);
		-webkit-backdrop-filter: blur(14px);
		backdrop-filter: blur(14px);
		box-shadow: 0 24px 60px -20px rgba(0, 0, 0, .6);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		transition: opacity .22s ease, transform .22s ease, visibility .22s;
	}
	.hexa-header.is-open .hexa-nav__menu { opacity: 1; visibility: visible; transform: translateY(0); }
	.hexa-nav__menu li { width: 100%; }
	.hexa-nav__menu a { display: block; padding: 12px 14px; border-radius: 12px; }
	.hexa-nav__menu .menu-item--cta a { justify-content: center; }
	.hexa-header.is-open .hexa-nav__toggle .hexa-nav__toggle-bar { transform: translate(-50%, -50%) rotate(45deg); }
	.hexa-header.is-open .hexa-nav__toggle .hexa-nav__toggle-bar::before { transform: translate(-50%, -50%) rotate(90deg); opacity: 0; }
	.hexa-header.is-open .hexa-nav__toggle .hexa-nav__toggle-bar::after { transform: translate(-50%, -50%); }
}

@media (max-width: 680px) {
	.hexa-pilares .hexa-cards,
	.hexa-planes .hexa-plans { flex-direction: column; }
	.hexa-pilares .hexa-card,
	.hexa-plan { width: 100%; flex: 1 1 auto; }
	.hexa-stats { flex-wrap: wrap; gap: 18px; }
	.hexa-stat { flex: 1 1 40%; }
	.hexa-badge-float--rule { left: 0; }
	.hexa-badge-float--sii { right: 0; }
	.hexa-footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* Respeta usuarios con reduce-motion */
@media (prefers-reduced-motion: reduce) {
	* { scroll-behavior: auto !important; }
	.hexa-pilares .hexa-card:hover,
	.hexa-btn-light:hover,
	.hexa-btn-light .elementor-button:hover { transform: none; }
}
