/**
 * Heading Animation Widget Styles
 */

.sellio-heading-animation {
	margin: 0;
	padding: 0;
	line-height: 1.2;
}

.sellio-heading-animation.text-gradient {
	padding-bottom: var(--gradient-b-offset, 0px);
	margin-bottom: calc(var(--gradient-b-offset, 0px) * -1);
	color: transparent !important;
	-webkit-text-fill-color: transparent !important;
	text-fill-color: transparent !important;
	-webkit-background-clip: text !important;
	background-clip: text !important;
	margin-inline: auto;
	display: inline-block;
	background-size: 100% 100% !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
}

.sellio-heading-animation.gradient-trigger {
	--gradient-int: 0;
}

/* Ensure text is visible when gradient is disabled */
.sellio-heading-animation:not(.text-gradient) {
	color: inherit;
}

/* Hover state */
.sellio-heading-animation.gradient-trigger:hover {
	cursor: pointer;
}

/* Rotating Word Styles */
.sellio-rotating-word {
	display: inline-block;
	position: relative;
	vertical-align: baseline;
	/* Enable hardware acceleration for smoother animations */
	transform: translateZ(0);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Animation Type: Bounce */
@keyframes sellioBounce {
	0%, 20%, 50%, 80%, 100% {
		transform: translateY(0) scale(1);
	}
	40% {
		transform: translateY(-15px) scale(1.05);
	}
	60% {
		transform: translateY(-8px) scale(1.02);
	}
}

.sellio-rotating-word.word-animation-bounce {
	animation-duration: 0.6s;
	animation-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
	will-change: transform;
}

/* Animation Type: Fade */
.sellio-rotating-word.word-animation-fade {
	transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	will-change: opacity;
}

/* Animation Type: Slide */
.sellio-rotating-word.word-animation-slide {
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	transform-origin: center;
	will-change: transform, opacity;
}

/* Animation Type: Flip */
.sellio-rotating-word.word-animation-flip {
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
	transform-style: preserve-3d;
	perspective: 1000px;
	backface-visibility: hidden;
	will-change: transform, opacity;
}

/* Animation Type: Typing */
.sellio-rotating-word.word-animation-typing {
	position: relative;
	will-change: contents;
}

.sellio-rotating-word.word-animation-typing.typing-active::after {
	content: '|';
	animation: sellioBlink 1s infinite;
	margin-left: 3px;
	font-weight: 300;
	opacity: 0.8;
	display: inline-block;
}

@keyframes sellioBlink {
	0%, 45% {
		opacity: 0.8;
	}
	50%, 100% {
		opacity: 0.2;
	}
}

/* Animation Type: Vertical Slide with Brackets */
.sellio-rotating-word.sellio-vertical-slide-container {
	position: relative;
	display: inline-block;
	overflow: hidden;
	vertical-align: baseline;
	height: 1.2em;
	line-height: 1.2em;
}

.sellio-rotating-word.sellio-vertical-slide-container .sellio-rotating-word-text {
	display: none;
}

.sellio-rotating-word.sellio-vertical-slide-container .sellio-rotating-word-list {
	margin: 0;
	padding: 0 1.5em 0 1.5em;
	text-align: left;
	list-style: none;
	display: block;
	animation-name: sellioVerticalSlide;
	animation-duration: 10s;
	animation-iteration-count: infinite;
	animation-timing-function: ease-in-out;
	position: relative;
}

.sellio-rotating-word.sellio-vertical-slide-container .sellio-rotating-word-item {
	line-height: 1.2em;
	margin: 0;
	padding: 0;
	display: block;
	height: 1.2em;
}

/* Brackets */
.sellio-rotating-word.sellio-vertical-slide-container::before,
.sellio-rotating-word.sellio-vertical-slide-container::after {
	position: absolute;
	top: 0;
	color: inherit;
	font-size: 1.2em;
	line-height: 1.2em;
	animation-name: sellioBracketOpacity;
	animation-duration: 2s;
	animation-iteration-count: infinite;
	z-index: 2;
	pointer-events: none;
	font-weight: 600;
}

.sellio-rotating-word.sellio-vertical-slide-container::before {
	content: '[';
	left: 0;
}

.sellio-rotating-word.sellio-vertical-slide-container::after {
	content: ']';
	right: 0;
}

@keyframes sellioBracketOpacity {
	0%, 100% {
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
}

/* Vertical slide animation - works for 2-8 words dynamically */
@keyframes sellioVerticalSlide {
	/* For 2 words */
	0%, 45%, 100% {
		transform: translate3d(0, 0, 0);
	}
	50%, 95% {
		transform: translate3d(0, -50%, 0);
	}
}

/* Adjust for more words - this will be handled dynamically via JS or can be extended */
.sellio-rotating-word.sellio-vertical-slide-container[data-word-count="3"] .sellio-rotating-word-list {
	animation-name: sellioVerticalSlide3;
}

.sellio-rotating-word.sellio-vertical-slide-container[data-word-count="4"] .sellio-rotating-word-list {
	animation-name: sellioVerticalSlide4;
}

@keyframes sellioVerticalSlide3 {
	0%, 28.33%, 100% {
		transform: translate3d(0, 0, 0);
	}
	33.33%, 61.66% {
		transform: translate3d(0, -33.33%, 0);
	}
	66.66%, 94.99% {
		transform: translate3d(0, -66.66%, 0);
	}
}

@keyframes sellioVerticalSlide4 {
	0%, 12.66%, 100% {
		transform: translate3d(0, 0, 0);
	}
	16.66%, 29.32% {
		transform: translate3d(0, -25%, 0);
	}
	33.32%, 45.98% {
		transform: translate3d(0, -50%, 0);
	}
	49.98%, 62.64% {
		transform: translate3d(0, -75%, 0);
	}
	66.64%, 79.3% {
		transform: translate3d(0, -50%, 0);
	}
	83.3%, 95.96% {
		transform: translate3d(0, -25%, 0);
	}
}

/* Fallback for other word counts - use generic animation */
.sellio-rotating-word.sellio-vertical-slide-container:not([data-word-count="3"]):not([data-word-count="4"]) .sellio-rotating-word-list {
	animation-name: sellioVerticalSlide;
}

/* Rotating word should not inherit gradient - reset background clipping but allow style controls to set color */
.sellio-heading-animation.text-gradient .sellio-rotating-word {
	background-image: none !important;
	-webkit-background-clip: initial !important;
	background-clip: initial !important;
	/* Reset text fill to allow style controls to work */
	-webkit-text-fill-color: initial !important;
}

