/**
 * ESPE Sticky Sidebar — layout grid en padre + estados drawer / colapsado.
 *
 * @package Widgets_ESPE
 */

/* -------------------------------------------------------------------------
   Wrapper (recibe variables desde Elementor {{WRAPPER}})
   ------------------------------------------------------------------------- */
.wespe-sidebar-wrapper {
	--wespe-width: 290px;
	--wespe-collapsed-width: 78px;
	--wespe-sticky-offset: 120px;
	--wespe-sidebar-extra-top: 28px;
	--wespe-gap: 28px;
	--wespe-fab-bottom: 108px;
	--wespe-fab-right: 20px;
	--wespe-fab-z: 99980;
	/* Por debajo del header sticky típico (z~999+); sube solo si Premium tapa clics y ya corregiste pointer-events */
	--wespe-desktop-z: 90;
	/* Paleta por defecto (ESPE / capturas) */
	--wespe-color-brand: #006a44;
	--wespe-color-brand-hover: #007d52;
	--wespe-color-active: #33a16d;
	position: relative;
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/*
 * Si el JS no puede montar el grid (ej. menú del tema, un solo bloque en la fila),
 * limitar ancho al sidebar evita que el bloque herede 300px+ del <li> / contenedor padre.
 */
.wespe-sidebar-wrapper:not(.wespe--drawer-bp) {
	max-width: min(100%, var(--wespe-width));
	position: relative;
	z-index: var(--wespe-desktop-z);
	isolation: isolate;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) {
	max-width: min(100%, var(--wespe-collapsed-width));
}

/* Primera pista del grid: contenedor Elementor que aloja el sidebar (clase aplicada por JS) */
.wespe-parent-layout > .wespe-sidebar-column {
	width: var(--wespe-width);
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}

.wespe-parent-layout > .wespe-sidebar-column.wespe-is-collapsed {
	width: var(--wespe-collapsed-width);
}

.wespe-parent-layout > .wespe-content-stack {
	min-width: 0;
	grid-column: auto;
	align-self: start;
}

/* -------------------------------------------------------------------------
   Reorganización desktop: grid en el padre inmediato de hermanos Elementor
   ------------------------------------------------------------------------- */
.wespe-parent-layout {
	display: grid !important;
	grid-template-columns: minmax(0, var(--wespe-layout-col1, var(--wespe-width))) minmax(0, 1fr) !important;
	column-gap: var(--wespe-gap) !important;
	/* stretch: la fila tiene la altura del contenido; la columna del sidebar debe ser
	   igual de alta para que position:sticky del aside tenga recorrido hasta el final */
	align-items: stretch !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

/* Hermanos detrás del stack (footer, etc.): ancho completo; no forman tercera celda estrecha */
.wespe-parent-layout > *:not(.wespe-sidebar-column):not(.wespe-content-stack) {
	grid-column: 1 / -1;
}

/*
 * Cadena flex en la columna del widget: Elementor envuelve el HTML en contenedores
 * cortos; sin altura “completa”, el sticky queda limitado al alto del propio menú.
 */
.wespe-parent-layout > .wespe-sidebar-column {
	display: flex;
	flex-direction: column;
	align-self: stretch;
	min-height: 0;
	overflow: visible;
}

.wespe-parent-layout > .wespe-sidebar-column > .elementor-widget-container,
.wespe-parent-layout > .wespe-sidebar-column > .elementor-widget-wrap {
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

.wespe-parent-layout > .wespe-sidebar-column .wespe-sidebar-wrapper {
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	flex-direction: column;
}

.wespe-parent-layout > .wespe-sidebar-column .wespe-sidebar {
	align-self: flex-start;
}

/* Flex container de Elementor: al aplicar grid, los hijos pasan a celdas */
.wespe-parent-layout.e-con,
.wespe-parent-layout.e-flex {
	flex-wrap: unset !important;
}

/* -------------------------------------------------------------------------
   Panel lateral
   ------------------------------------------------------------------------- */
.wespe-sidebar {
	position: sticky;
	top: calc(var(--wespe-sticky-offset) + var(--wespe-sidebar-extra-top, 0px));
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid rgba(0, 106, 68, 0.12);
	border-radius: 16px;
	box-shadow: 0 12px 32px rgba(0, 106, 68, 0.08);
	padding: 14px;
	transition:
		width 0.28s ease,
		transform 0.28s ease,
		opacity 0.28s ease,
		box-shadow 0.28s ease;
	z-index: 20;
}

.wespe-sidebar__topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
	flex-shrink: 0;
}

.wespe-sidebar__scroll {
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.wespe-sidebar__scroll::-webkit-scrollbar {
	width: 6px;
}

.wespe-sidebar__scroll::-webkit-scrollbar-thumb {
	background: rgba(15, 23, 42, 0.18);
	border-radius: 999px;
}

.wespe-sidebar__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.wespe-sidebar__item {
	margin: 0;
}

.wespe-sidebar__link {
	position: relative;
	width: 100%;
	display: flex;
	align-items: center;
	gap: 12px;
	border: 0;
	cursor: pointer;
	text-align: left;
	background: var(--wespe-color-brand);
	color: #fff;
	padding: 12px 14px;
	border-radius: 10px;
	transition:
		background-color 0.22s ease,
		color 0.22s ease,
		transform 0.22s ease;
	font: inherit;
}

.wespe-sidebar-wrapper:not(.is-collapsed) .wespe-sidebar__link:hover {
	background: var(--wespe-color-brand-hover);
	transform: translateX(2px);
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__link:hover {
	background: var(--wespe-color-brand-hover);
}

.wespe-sidebar__item.is-active .wespe-sidebar__link {
	background: var(--wespe-color-active);
	color: #fff;
}

.wespe-sidebar__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	min-width: 22px;
	line-height: 1;
	font-size: 18px;
	flex-shrink: 0;
}

.wespe-sidebar__icon svg {
	display: block;
	width: 1em;
	height: 1em;
}

.wespe-sidebar__link-text {
	flex: 1 1 auto;
	min-width: 0;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.35;
}

.wespe-sidebar__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	padding: 3px 8px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
	flex-shrink: 0;
}

/* Botones */
.wespe-sidebar__toggle,
.wespe-sidebar__drawer-button,
.wespe-sidebar__drawer-close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border: 0;
	cursor: pointer;
	background: var(--wespe-color-brand);
	color: #fff;
	border-radius: 999px;
	padding: 10px 14px;
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
	min-height: 44px;
	transition:
		opacity 0.2s ease,
		transform 0.2s ease,
		background-color 0.2s ease;
	font: inherit;
}

.wespe-sidebar__toggle:hover,
.wespe-sidebar__drawer-button:hover,
.wespe-sidebar__drawer-close:hover {
	opacity: 0.94;
}

.wespe-sidebar__toggle-icon svg,
.wespe-sidebar__drawer-icon svg {
	display: block;
	width: 1.1em;
	height: 1.1em;
}

/* Escritorio: expandido = « contraer; colapsado = » expandir; icono Elementor oculto */
.wespe-sidebar-wrapper:not(.wespe--drawer-bp) .wespe-sidebar__toggle-icon {
	display: none !important;
}

.wespe-sidebar-wrapper:not(.wespe--drawer-bp) .wespe-sidebar__toggle-text {
	display: none !important;
}

.wespe-sidebar__toggle-icon-fallback {
	display: none;
	align-items: center;
	justify-content: center;
	font-size: 1.45rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.06em;
	color: inherit;
}

.wespe-sidebar-wrapper:not(.wespe--drawer-bp) .wespe-sidebar__toggle-icon-fallback {
	display: inline-flex !important;
}

.wespe-sidebar-wrapper:not(.wespe--drawer-bp) .wespe-sidebar__toggle-fallback-collapsed {
	display: none !important;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__toggle-fallback-expanded {
	display: none !important;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__toggle-fallback-collapsed {
	display: inline !important;
}

.wespe-sidebar-wrapper:not(.wespe--drawer-bp) .wespe-sidebar__toggle {
	width: 100%;
	justify-content: center;
	gap: 0;
	padding-left: 10px;
	padding-right: 10px;
}

.wespe-sidebar__drawer-button {
	display: none;
	width: fit-content;
	max-width: 100%;
	margin-bottom: 12px;
	flex-wrap: wrap;
}

/* FAB móvil: icono circular fijo (el texto se oculta vía clase .wespe-drawer-fab--detached) */
.wespe-sidebar__drawer-button.wespe-drawer-fab--detached {
	position: fixed !important;
	right: var(--wespe-fab-right, 20px) !important;
	bottom: var(--wespe-fab-bottom, 108px) !important;
	left: auto !important;
	top: auto !important;
	z-index: var(--wespe-fab-z, 99980) !important;
	width: 52px !important;
	height: 52px !important;
	min-height: 52px !important;
	padding: 0 !important;
	margin: 0 !important;
	border-radius: 50% !important;
	/* En body no hereda --wespe-color-* del wrapper; JS copia vars; estos son respaldo */
	background-color: var(--wespe-color-brand, #006a44) !important;
	color: #fff !important;
	opacity: 1 !important;
	box-shadow: 0 8px 26px rgba(0, 106, 68, 0.38);
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 0 !important;
}

.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-text {
	display: none !important;
}

.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-icon {
	color: #fff !important;
}

.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-icon svg {
	width: 1.45em;
	height: 1.45em;
}

.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-icon svg,
.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-icon svg * {
	fill: currentColor !important;
}

.wespe-sidebar__drawer-button.wespe-drawer-fab--detached .wespe-sidebar__drawer-icon i {
	color: inherit !important;
}

.wespe-sidebar__drawer-close {
	display: none;
	width: 40px;
	height: 40px;
	padding: 0;
	font-size: 22px;
	margin-left: auto;
	flex-shrink: 0;
}

.wespe-sidebar__overlay {
	display: none;
	pointer-events: none !important;
}

.wespe-sidebar-wrapper.is-drawer-open .wespe-sidebar__overlay {
	pointer-events: auto !important;
}

/* -------------------------------------------------------------------------
   Colapsado (desktop)
   ------------------------------------------------------------------------- */
/* Mantener sticky: no usar position:relative aquí (anula position:sticky del panel) */
.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar {
	width: 100%;
	z-index: 1;
}

/* Escritorio colapsado: sin panel interno scrolleable (evita barra y clics perdidos) */
.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar {
	display: flex;
	flex-direction: column;
	overflow: visible;
	position: sticky;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) {
	overflow: visible;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__topbar {
	flex-shrink: 0;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__scroll {
	flex: 0 0 auto;
	min-height: 0;
	max-height: none !important;
	height: auto !important;
	overflow: visible !important;
	-webkit-overflow-scrolling: auto;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__link {
	justify-content: center;
	padding-left: 10px;
	padding-right: 10px;
	position: relative;
	z-index: 2;
	cursor: pointer;
	pointer-events: auto;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__link-text,
.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__badge {
	display: none !important;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__toggle {
	position: relative;
	z-index: 2;
	cursor: pointer;
	pointer-events: auto;
}

/* Tooltip nativo del plugin (visible solo colapsado) */
.wespe-sidebar__tooltip {
	display: none;
}

/* Escritorio colapsado: tooltip a la derecha, una sola línea; fuente pequeña */
.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__tooltip {
	display: block;
	position: absolute;
	left: 100%;
	right: auto;
	top: 50%;
	bottom: auto;
	margin-left: 10px;
	transform: translateY(-50%) translateX(-4px);
	padding: 5px 9px;
	border-radius: 6px;
	background: #0f172a;
	color: #fff;
	font-size: 10px;
	font-weight: 600;
	line-height: 1.2;
	text-align: left;
	white-space: nowrap;
	word-wrap: normal;
	hyphens: none;
	max-width: min(320px, calc(100vw - 32px));
	overflow: hidden;
	text-overflow: ellipsis;
	z-index: 5;
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition:
		opacity 0.2s ease,
		transform 0.2s ease,
		visibility 0.2s;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.22);
	border: 1px solid rgba(255, 255, 255, 0.08);
	box-sizing: border-box;
}

.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__link:hover .wespe-sidebar__tooltip,
.wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__link:focus-visible .wespe-sidebar__tooltip {
	opacity: 1;
	visibility: visible;
	transform: translateY(-50%) translateX(0);
}

html[dir='rtl'] .wespe-sidebar-wrapper.is-collapsed:not(.wespe--drawer-bp) .wespe-sidebar__tooltip {
	left: auto;
	right: 100%;
	margin-left: 0;
	margin-right: 10px;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__item {
	position: relative;
	z-index: 0;
}

.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__link:hover,
.wespe-sidebar-wrapper.is-collapsed .wespe-sidebar__link:focus-visible {
	z-index: 5;
}

/* -------------------------------------------------------------------------
   Drawer (breakpoint aplicado por JS: .wespe--drawer-bp)
   ------------------------------------------------------------------------- */
/* El botón drawer solo es visible como FAB (.wespe-drawer-fab--detached en body; sidebar.js) */

/* En móvil drawer: solo cerrar con ×; “Contraer” no aplica */
.wespe-sidebar-wrapper.wespe--drawer-bp .wespe-sidebar__toggle {
	display: none !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp .wespe-sidebar__toggle-icon-fallback {
	display: none !important;
}

/* En modo drawer el JS quita .wespe-parent-layout; estos estilos cubren el wrapper a ancho completo */
.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer {
	width: 100% !important;
	max-width: 100% !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer .wespe-sidebar {
	position: fixed;
	top: 0;
	right: 0;
	left: auto;
	height: 100vh;
	height: 100dvh;
	width: min(88vw, var(--wespe-width));
	max-width: min(88vw, 420px);
	border-radius: 18px 0 0 18px;
	transform: translateX(110%);
	z-index: 99991;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	padding: 14px;
	box-sizing: border-box;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer .wespe-sidebar__scroll {
	flex: 1;
	min-height: 0;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer .wespe-sidebar__drawer-close {
	display: inline-flex;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer .wespe-sidebar__overlay {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.38);
	z-index: 99990;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
	display: block;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-drawer-open .wespe-sidebar {
	transform: translateX(0);
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-drawer-open .wespe-sidebar__overlay {
	opacity: 1;
	pointer-events: auto;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar {
	width: min(88vw, var(--wespe-width));
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__link {
	justify-content: flex-start;
	padding-left: 14px;
	padding-right: 14px;
}

/* En drawer el “colapsado” vuelve a mostrar textos: anular display:none del escritorio */
.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__link-text {
	display: inline !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__badge {
	display: inline-flex !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__toggle-text {
	display: inline !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__toggle-icon {
	display: inline-flex !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__toggle-icon-fallback {
	display: none !important;
}

.wespe-sidebar-wrapper.wespe--drawer-bp.has-mobile-drawer.is-collapsed .wespe-sidebar__tooltip {
	display: none !important;
}

.wespe-body-has-drawer {
	touch-action: none;
}

/* Vacío / editor */
.wespe-sidebar__empty {
	border: 1px dashed #cbd5e1;
	border-radius: 14px;
	padding: 14px;
	color: #475569;
	font-size: 14px;
}

/* -------------------------------------------------------------------------
   Premium Addons — menú móvil: capas que a veces quedan encima en escritorio
   (≥1024px). Si el menú hamburguesa deja de responder en desktop, comenta este bloque.
   ------------------------------------------------------------------------- */
@media (min-width: 1024px) {
	.premium-nav-slide-overlay,
	.premium-mobile-menu-outer-container {
		pointer-events: none !important;
	}

	.premium-hamburger-toggle.premium-mobile-menu-icon {
		pointer-events: auto !important;
	}
}
