/* ==========================================================================
   Danalyx Side Menu – Public CSS
   Prefix: dsmx-*
   Version: 1.0.4
   ========================================================================== */

/* Root defaults (instance-specific vars are injected inline per menu) */
.dsmx-wrap {
	--dsmx-width: 320px;
	--dsmx-pad: 30px 20px;
	--dsmx-link-size: 18px;
	--dsmx-link-weight: 500;
	--dsmx-text: #ffffff;
	--dsmx-text-hover: #ff3b30;
	--dsmx-divider: 1px solid #333333;
	--dsmx-item-gap: 12px;
	--dsmx-btn-radius: 8px;
	--dsmx-btn-bg: #ff3b30;
	--dsmx-btn-color: #ffffff;
	--dsmx-btn-bg-hover: #d62b22;
	--dsmx-btn-color-hover: #ffffff;
	--dsmx-btn-pad: 10px 16px;

	/* Logo + animation vars (instance overrides come from renderer) */
	--dsmx-logo-max-w: 140px;
	--dsmx-logo-justify: center;

	/* Toggle/close defaults (overridable per instance) */
	--dsmx-toggle-fg: inherit;
	--dsmx-toggle-bg: transparent;
	--dsmx-toggle-fg-hover: inherit;
	--dsmx-toggle-bg-hover: transparent;

	--dsmx-close-fg: var(--dsmx-text);
	--dsmx-close-bg: transparent;
	--dsmx-close-fg-hover: var(--dsmx-text-hover);
	--dsmx-close-bg-hover: transparent;

	/* Utility: ease/duration (JS may set inline) */
	--dsmx-dur: 400ms;
	--dsmx-ease: ease-in-out;
}

/* Wrapper */
.dsmx-wrap {
	position: fixed;
	inset: 0;
	z-index: 99999;
	pointer-events: none;
}

/* Overlay (inline background is injected by renderer) */
.dsmx-overlay {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 220ms ease-in-out;
	pointer-events: none;
}

/* Panel */
.dsmx-panel {
	position: absolute;
	top: 0;
	bottom: 0;
	width: var(--dsmx-width);
	background: #111;
	color: var(--dsmx-text);
	padding: var(--dsmx-pad);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	transform: translate3d(0,0,0);
	will-change: transform, opacity;
	transition: transform var(--dsmx-dur, 400ms) var(--dsmx-ease, ease-in-out), opacity 200ms ease;

	/* Default placement: right slides in */
	right: 0;
	transform: translateX(100%);
	opacity: 1;

	box-sizing: border-box;
	box-shadow: 3px 0 10px rgba(0,0,0,0.40);
}

/* Placement: LEFT */
.dsmx-place-left .dsmx-panel {
	left: 0;
	right: auto;
	transform: translateX(-100%);
}

/* When open */
.dsmx-wrap.is-open { pointer-events: auto; }
.dsmx-wrap.is-open .dsmx-overlay { opacity: 1; pointer-events: auto; }

.dsmx-place-right.is-open .dsmx-panel,
.dsmx-place-right.dsmx-openon-hover:hover .dsmx-panel { transform: translateX(0); }

.dsmx-place-left.is-open .dsmx-panel,
.dsmx-place-left.dsmx-openon-hover:hover .dsmx-panel { transform: translateX(0); }

/* Close button */
.dsmx-close {
	position: sticky;
	top: 0;
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: none;
	border-radius: 999px;
	background: var(--dsmx-close-bg, transparent);
	color: var(--dsmx-close-fg, var(--dsmx-text));
	cursor: pointer;
	transition: transform 300ms ease, color 200ms ease, background 200ms ease;
	box-shadow: none;
}
.dsmx-close:hover,
.dsmx-close:focus {
	transform: rotate(90deg);
	color: var(--dsmx-close-fg-hover, var(--dsmx-text-hover));
	background: var(--dsmx-close-bg-hover, transparent);
}
.dsmx-close:focus-visible {
	outline: 2px solid var(--dsmx-text-hover);
	outline-offset: 2px;
}

/* Logo */
.dsmx-logo-wrap {
	display: flex;
	justify-content: var(--dsmx-logo-justify);
	align-items: center;
	margin: 24px 0 24px;
	padding-bottom: 16px;
}
.dsmx-logo {
	max-width: var(--dsmx-logo-max-w);
	height: auto;
	display: block;
}

/* Logo hover effects */
.dsmx-logo-wrap.dsmx-logo-pulse .dsmx-logo { transition: transform 200ms ease; }
.dsmx-logo-wrap.dsmx-logo-pulse:hover .dsmx-logo { transform: scale(1.05); }

.dsmx-logo-wrap.dsmx-logo-spin .dsmx-logo { transition: transform 300ms ease; }
.dsmx-logo-wrap.dsmx-logo-spin:hover .dsmx-logo { transform: rotate(360deg); }

.dsmx-logo-wrap.dsmx-logo-tilt .dsmx-logo { transition: transform 200ms ease; }
.dsmx-logo-wrap.dsmx-logo-tilt:hover .dsmx-logo { transform: rotate(-6deg); }

.dsmx-logo-wrap.dsmx-logo-float .dsmx-logo { transition: transform 300ms ease; }
.dsmx-logo-wrap.dsmx-logo-float:hover .dsmx-logo { transform: translateY(-4px); }

.dsmx-logo-wrap.dsmx-logo-glow .dsmx-logo { transition: filter 200ms ease; }
.dsmx-logo-wrap.dsmx-logo-glow:hover .dsmx-logo { filter: drop-shadow(0 0 10px rgba(255,255,255,0.35)); }

/* Navigation */
.dsmx-nav { margin: 0; padding: 0; }
.dsmx-list { list-style: none; margin: 0; padding: 0; }
.dsmx-item { margin: 0; padding: 0; }
.dsmx-item + .dsmx-item {
	margin-top: var(--dsmx-item-gap);
	border-top: var(--dsmx-divider);
	padding-top: calc(var(--dsmx-item-gap) * 0.5);
}
.dsmx-link {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	color: var(--dsmx-text);
	font-size: var(--dsmx-link-size);
	font-weight: var(--dsmx-link-weight);
	line-height: 1.35;
	transition: color 160ms ease, transform 200ms ease;
}
.dsmx-link:hover,
.dsmx-link:focus { color: var(--dsmx-text-hover); }
.dsmx-item-icon {
	width: 18px;
	height: 18px;
	object-fit: contain;
}

/* Buttons (can be applied via custom JSON or WP menu CSS class "dsmx-button") */
.dsmx-item.dsmx-button .dsmx-link {
	background: var(--dsmx-btn-bg);
	color: var(--dsmx-btn-color);
	border-radius: var(--dsmx-btn-radius);
	padding: var(--dsmx-btn-pad);
	justify-content: center;
	text-align: center;
}
.dsmx-item.dsmx-button .dsmx-link:hover,
.dsmx-item.dsmx-button .dsmx-link:focus {
	background: var(--dsmx-btn-bg-hover);
	color: var(--dsmx-btn-color-hover);
	transform: translateY(-1px);
}

/* Submenus (WP) */
.dsmx-item .sub-menu {
	list-style: none;
	margin: 6px 0 0 0;
	padding: 0 0 0 14px;
	border-left: var(--dsmx-divider);
}
.dsmx-openon-hover .dsmx-item:hover > .sub-menu { display: block; }

/* Overlay click target visibility control happens through is-open */
.dsmx-overlay { pointer-events: none; }
.dsmx-wrap.is-open .dsmx-overlay { pointer-events: auto; }

/* OPEN ON HOVER (alternative to click) */
.dsmx-openon-hover { pointer-events: auto; }

/* Panel Modes (optional body classes toggled by JS for pushing content) */
body.dsmx-push-right { margin-right: var(--dsmx-width); transition: margin 300ms ease; }
body.dsmx-push-left  { margin-left:  var(--dsmx-width); transition: margin 300ms ease; }

/* ===================== Toggle button (for widget/shortcode) ===================== */
.dsmx-toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border: none !important;
	background: var(--dsmx-toggle-bg, transparent) !important;
	color: var(--dsmx-toggle-fg, inherit) !important;
	cursor: pointer;
	font: inherit;
	padding: 6px 10px;
	line-height: 1;
	transition: transform 180ms ease, opacity 150ms ease, background 160ms ease, color 160ms ease;
	box-shadow: none !important;
	width: auto !important;
	height: auto !important;
	min-width: 0 !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	border-radius: 8px;
	text-decoration: none !important;
}
.dsmx-toggle:hover,
.dsmx-toggle:focus {
	transform: translateY(-1px);
	background: var(--dsmx-toggle-bg-hover, var(--dsmx-toggle-bg, transparent)) !important;
	color: var(--dsmx-toggle-fg-hover, var(--dsmx-toggle-fg, inherit)) !important;
}
.dsmx-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* Alignment helpers for inline toggle */
.dsmx-toggle.dsmx-align-left   { justify-content: flex-start; }
.dsmx-toggle.dsmx-align-center { justify-content: center; width: 100%; }
.dsmx-toggle.dsmx-align-right  { justify-content: flex-end; width: 100%; }

/* Icon + label handling */
.dsmx-toggle .dsmx-icon { display: inline-flex; line-height: 1; }
.dsmx-toggle .dsmx-label { display: inline-block; }
.dsmx-toggle .dsmx-label:empty { display: none; }
/* Icon-only mode hides label */
.dsmx-toggle[data-icon-only="true"] .dsmx-label,
.dsmx-toggle.dsmx-has-icon-only .dsmx-label { display: none; }

/* Make icons inherit chosen color (SVG + font + fallback char) */
.dsmx-toggle i,
.dsmx-toggle svg { display: inline-block; vertical-align: middle; color: inherit; fill: currentColor; stroke: currentColor; }
.dsmx-toggle svg * { fill: currentColor !important; stroke: currentColor !important; }
.dsmx-toggle [class^="eicon"]:before,
.dsmx-toggle [class*=" eicon"]:before { color: inherit !important; }
.dsmx-toggle .dsmx-icon-fallback { display: inline-block; color: inherit; line-height: 1; }

/* Toggle animations (optional) */
.dsmx-toggle.dsmx-anim-pulse:hover { transform: scale(1.04); }
.dsmx-toggle.dsmx-anim-grow:hover  { transform: scale(1.08); }
.dsmx-toggle.dsmx-anim-spin:hover  { transform: rotate(90deg); }
@keyframes dsmx-shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-2px)} 75%{transform:translateX(2px)} }
.dsmx-toggle.dsmx-anim-shake:hover { animation: dsmx-shake 240ms linear; }

/* Kill Elementor/editor default button look that might force blue bg */
.elementor .elementor-widget button.dsmx-toggle,
.elementor .elementor-widget a.dsmx-toggle {
	background: var(--dsmx-toggle-bg, transparent) !important;
	color: var(--dsmx-toggle-fg, inherit) !important;
	border: none !important;
	box-shadow: none !important;
	text-decoration: none !important;
}
.elementor .elementor-widget button.dsmx-toggle:hover,
.elementor .elementor-widget a.dsmx-toggle:hover {
	background: var(--dsmx-toggle-bg-hover, var(--dsmx-toggle-bg, transparent)) !important;
	color: var(--dsmx-toggle-fg-hover, var(--dsmx-toggle-fg, inherit)) !important;
}

/* ===================== Animations for panel ===================== */
/* Fade */
.dsmx-wrap[data-anim-open="fade"] .dsmx-panel { opacity: 0; transform: none; }
.dsmx-wrap.is-open[data-anim-open="fade"] .dsmx-panel {
	opacity: 1; transition: opacity var(--dsmx-dur, 400ms) var(--dsmx-ease, ease-in-out);
}

/* Scale */
.dsmx-wrap[data-anim-open="scale"] .dsmx-panel { transform: scale(0.96); transform-origin: right top; opacity: 0; }
.dsmx-place-left[data-anim-open="scale"] .dsmx-panel { transform-origin: left top; }
.dsmx-wrap.is-open[data-anim-open="scale"] .dsmx-panel {
	transform: scale(1); opacity: 1;
	transition: transform var(--dsmx-dur, 400ms) var(--dsmx-ease, ease-in-out), opacity 220ms ease;
}

/* Flip */
.dsmx-wrap[data-anim-open="flip"] .dsmx-panel { transform: rotateY(90deg); transform-origin: right center; opacity: 0; }
.dsmx-place-left[data-anim-open="flip"] .dsmx-panel { transform-origin: left center; }
.dsmx-wrap.is-open[data-anim-open="flip"] .dsmx-panel {
	transform: rotateY(0); opacity: 1;
	transition: transform var(--dsmx-dur, 500ms) var(--dsmx-ease, ease), opacity 200ms ease;
}

/* Door */
.dsmx-wrap[data-anim-open="door"] .dsmx-panel { transform-origin: right center; transform: perspective(900px) rotateY(-90deg); opacity: 0; }
.dsmx-place-left[data-anim-open="door"] .dsmx-panel { transform-origin: left center; transform: perspective(900px) rotateY(90deg); }
.dsmx-wrap.is-open[data-anim-open="door"] .dsmx-panel {
	transform: perspective(900px) rotateY(0deg); opacity: 1;
	transition: transform var(--dsmx-dur, 520ms) var(--dsmx-ease, ease), opacity 220ms ease;
}

/* Bounce (simple pop-in) */
@keyframes dsmx-bounce-in {
	0%   { transform: translateX(8%) scale(0.98); opacity: 0; }
	60%  { transform: translateX(-2%) scale(1.01); opacity: 1; }
	100% { transform: translateX(0) scale(1); }
}
.dsmx-wrap[data-anim-open="bounce"].is-open .dsmx-panel {
	animation: dsmx-bounce-in var(--dsmx-dur, 420ms) var(--dsmx-ease, ease-out) both;
}
.dsmx-place-left[data-anim-open="bounce"].is-open .dsmx-panel { animation-name: dsmx-bounce-in; }

/* Close variants (fade/scale/flip use transitions below) */
.dsmx-wrap[data-anim-close="fade"] .dsmx-panel { transition: opacity var(--dsmx-dur, 300ms) var(--dsmx-ease, ease-in-out); }
.dsmx-wrap:not(.is-open)[data-anim-close="fade"] .dsmx-panel { opacity: 0; }

.dsmx-wrap[data-anim-close="scale"] .dsmx-panel {
	transition: transform var(--dsmx-dur, 300ms) var(--dsmx-ease, ease-in-out), opacity 200ms ease;
}
.dsmx-wrap:not(.is-open)[data-anim-close="scale"] .dsmx-panel { transform: scale(0.98); opacity: 0; }

.dsmx-wrap[data-anim-close="flip"] .dsmx-panel { transition: transform var(--dsmx-dur, 350ms) var(--dsmx-ease, ease-in); }
.dsmx-place-right:not(.is-open)[data-anim-close="flip"] .dsmx-panel { transform: rotateY(90deg); opacity: 0; }
.dsmx-place-left:not(.is-open)[data-anim-close="flip"] .dsmx-panel { transform: rotateY(-90deg); opacity: 0; }

/* Scrollbar (WebKit) */
.dsmx-panel::-webkit-scrollbar { width: 10px; }
.dsmx-panel::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.22); border-radius: 8px; }
.dsmx-panel::-webkit-scrollbar-track { background: rgba(255,255,255,0.06); }

/* Safe reduces for motion */
@media (prefers-reduced-motion: reduce) {
	.dsmx-overlay,
	.dsmx-panel,
	.dsmx-close,
	.dsmx-toggle {
		transition: none !important;
		animation: none !important;
	}
}

/* ===== Hardening inside the panel against theme/global styles ===== */
.dsmx-panel, .dsmx-panel * { box-sizing: border-box; }

/* Lists */
.dsmx-panel .dsmx-list,
.dsmx-panel .dsmx-list li { list-style: none !important; }
.dsmx-panel .dsmx-list { margin: 0 !important; padding: 0 !important; }
.dsmx-panel .dsmx-list > li { margin: 0 !important; padding-left: 0 !important; }

/* Links */
.dsmx-panel .dsmx-link,
.dsmx-panel a {
	color: var(--dsmx-text) !important;
	text-decoration: none !important;
}
.dsmx-panel .dsmx-link:hover,
.dsmx-panel a:hover,
.dsmx-panel .dsmx-link:focus {
	color: var(--dsmx-text-hover) !important;
}

/* Neutralize theme button styles on close */
.dsmx-panel .dsmx-close {
	background: transparent !important;
	border: none !important;
	color: var(--dsmx-close-fg, var(--dsmx-text)) !important;
	width: 36px !important;
	height: 36px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	border-radius: 999px !important;
	padding: 0 !important;
	box-shadow: none !important;
}
.dsmx-panel .dsmx-close:hover {
	color: var(--dsmx-close-fg-hover, var(--dsmx-text-hover)) !important;
	background: transparent !important;
	transform: rotate(90deg);
}

/* Prevent theme list rules from leaking in */
.dsmx-panel ul, .dsmx-panel ol { margin: 0 !important; padding: 0 !important; }
.dsmx-panel li { list-style: none !important; }








/* === DSMX: icon-only + hover hardening (append only) === */
button.dsmx-toggle, a.dsmx-toggle {
  background: var(--dsmx-toggle-bg,transparent) !important;
  color: var(--dsmx-toggle-fg,inherit) !important;
  border: none !important;
  box-shadow: none !important;
}

button.dsmx-toggle:hover, a.dsmx-toggle:hover,
button.dsmx-toggle:focus, a.dsmx-toggle:focus {
  background: var(--dsmx-toggle-bg-hover, var(--dsmx-toggle-bg,transparent)) !important;
  color: var(--dsmx-toggle-fg-hover, var(--dsmx-toggle-fg,inherit)) !important;
}

/* icon container + fallback */
.dsmx-toggle .dsmx-icon { line-height: 1; display: inline-flex; }
.dsmx-toggle .dsmx-icon-fallback { color: inherit; line-height: 1; }

/* make library icons adopt chosen colors */
.dsmx-toggle i, .dsmx-toggle svg { color: inherit; fill: currentColor; stroke: currentColor; }
.dsmx-toggle svg * { fill: currentColor !important; stroke: currentColor !important; }

/* hide label when icon-only is enabled */
.dsmx-toggle[data-icon-only="true"] .dsmx-label { display: none !important; }

/* kill Elementor's default "blue" button in editor */
.elementor .elementor-widget button.dsmx-toggle,
.elementor .elementor-widget a.dsmx-toggle {
  background: var(--dsmx-toggle-bg,transparent) !important;
  color: var(--dsmx-toggle-fg,inherit) !important;
  border: none !important;
  box-shadow: none !important;
}
.elementor .elementor-widget button.dsmx-toggle:hover,
.elementor .elementor-widget a.dsmx-toggle:hover {
  background: var(--dsmx-toggle-bg-hover, var(--dsmx-toggle-bg,transparent)) !important;
  color: var(--dsmx-toggle-fg-hover, var(--dsmx-toggle-fg,inherit)) !important;
}








/* DSMX: make SVGs inherit color; hide fallback when a library icon is present */
.dsmx-toggle i,
.dsmx-toggle svg { color: inherit; fill: currentColor; stroke: currentColor; }
.dsmx-toggle svg * { fill: currentColor !important; stroke: currentColor !important; }

/* If an SVG is inside .dsmx-icon, hide the fallback char */
.dsmx-toggle .dsmx-icon svg ~ .dsmx-icon-fallback { display: none !important; }

/* Icon-only really hides the label (works with both data-attr and legacy class) */
.dsmx-toggle[data-icon-only="true"] .dsmx-label,
.dsmx-toggle.dsmx-has-icon-only .dsmx-label { display: none !important; }

/* Win over Elementor’s default “blue button” in editor/front */
.elementor .elementor-widget button.dsmx-toggle,
.elementor .elementor-widget a.dsmx-toggle {
  background: var(--dsmx-toggle-bg, transparent) !important;
  color: var(--dsmx-toggle-fg, inherit) !important;
  border: none !important;
  box-shadow: none !important;
}
.elementor .elementor-widget button.dsmx-toggle:hover,
.elementor .elementor-widget a.dsmx-toggle:hover {
  background: var(--dsmx-toggle-bg-hover, var(--dsmx-toggle-bg, transparent)) !important;
  color: var(--dsmx-toggle-fg-hover, var(--dsmx-toggle-fg, inherit)) !important;
}






/* Hide text fallback when a library icon (svg/i) is rendered */
.dsmx-toggle .dsmx-icon.has-lib .dsmx-icon-fallback { display: none !important; }

/* Make sure library icons inherit your chosen color */
.dsmx-toggle i,
.dsmx-toggle svg { color: inherit; fill: currentColor; stroke: currentColor; }
.dsmx-toggle svg * { fill: currentColor !important; stroke: currentColor !important; }

/* EXTRA: also hide fallback when <i> is used (font icon) */
.dsmx-toggle .dsmx-icon i ~ .dsmx-icon-fallback { display: none !important; }












/* Nuke any pseudo bars some themes add on buttons */
.dsmx-toggle::before,
.dsmx-toggle::after { content: none !important; }







/* Prevent “empty box” due to collapsing inline content while fonts load */
.dsmx-toggle[data-icon-only="true"] .dsmx-icon {
  min-width: 1.2em;
  min-height: 1.2em;
  line-height: 1;
}
