/* Theme-specific interaction and state styles */

#tfwg-nav {
	box-shadow: var(--nav-shadow);
	border-color: hsl(var(--nav-border));
	background: hsl(var(--nav-bg));
}

#tfwg-nav.is-scrolled {
	background: hsl(var(--background) / 0.6);
}

#tfwg-nav > .flex.items-center.justify-between {
	padding-right: 24px;
}

.is-empty {
	display: none !important;
}

.reveal-up,
.reveal-left,
.reveal-right {
	opacity: 0;
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal-up {
	transform: translateY(20px);
}

.reveal-left {
	transform: translateX(-30px);
}

.reveal-right {
	transform: translateX(30px);
}

.reveal-up.is-visible,
.reveal-left.is-visible,
.reveal-right.is-visible {
	opacity: 1;
	transform: translate(0, 0);
}

#tfwg-consultation-dialog {
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

#tfwg-consultation-dialog.is-open {
	display: flex !important;
	opacity: 1;
	pointer-events: auto;
}

.tfwg-dialog-enter {
	transform: translateY(20px) scale(0.92);
	opacity: 0;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

#tfwg-consultation-dialog.is-open .tfwg-dialog-enter {
	transform: translateY(0) scale(1);
	opacity: 1;
}

body.tfwg-modal-open {
	overflow: hidden;
}

.faq-content {
	max-height: 0;
}

.faq-trigger[aria-expanded="true"] .faq-chevron svg {
	transform: rotate(90deg);
}

[data-mobile-menu].is-open {
	display: block !important;
}

.tfwg-theme-light .icon-sun,
html.light .icon-sun {
	display: none;
}

.tfwg-theme-light .icon-moon,
html.light .icon-moon {
	display: inline-flex !important;
	color: hsl(var(--foreground));
}

/* El SVG de la luna lleva la clase "hidden"; en modo claro debe verse */
.tfwg-theme-light .icon-moon svg,
html.light .icon-moon svg {
	display: block !important;
}

.tfwg-toast {
	position: fixed;
	bottom: 1.5rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 120;
	padding: 0.75rem 1rem;
	border-radius: 9999px;
	background: hsl(var(--card));
	color: hsl(var(--card-foreground));
	border: 1px solid hsl(var(--border));
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
	font-size: 0.875rem;
	max-width: calc(100% - 2rem);
	text-align: center;
}

.tfwg-toast.show {
	display: block !important;
}

@media (prefers-reduced-motion: reduce) {
	.reveal-up,
	.reveal-left,
	.reveal-right {
		transition: none;
		opacity: 1;
		transform: none;
	}
}
