/**
 * Syoska Motion Presets – erweiterte Bibliothek (Katalog 5×20).
 * Nutzt: var(--smp-accent), var(--smp-accent-2), var(--smp-duration), var(--smp-ease).
 */

/* ── Buttons (zusätzlich zu presets-buttons.css) ───────────────── */

.smp-btn-ripple-ring {
	position: relative;
	overflow: hidden;
	border-radius: var(--smp-radius);
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	text-decoration: none;
	border: none;
	cursor: pointer;
	isolation: isolate;
}

.smp-btn-ripple-ring::before {
	content: "";
	position: absolute;
	inset: -50%;
	background: radial-gradient(circle, color-mix(in srgb, #fff 35%, transparent) 0%, transparent 55%);
	opacity: 0;
	transform: scale(0.3);
	transition: opacity var(--smp-duration) var(--smp-ease), transform 0.55s var(--smp-ease-out);
}

.smp-btn-ripple-ring:hover::before,
.smp-btn-ripple-ring:focus-visible::before {
	opacity: 1;
	transform: scale(1);
}

.smp-btn-outline-fill {
	display: inline-flex;
	padding: 0.6em 1.2em;
	border: 2px solid var(--smp-accent);
	color: var(--smp-accent);
	background: transparent;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	transition: color var(--smp-duration) var(--smp-ease), background var(--smp-duration) var(--smp-ease), box-shadow var(--smp-duration) var(--smp-ease);
}

.smp-btn-outline-fill:hover,
.smp-btn-outline-fill:focus-visible {
	background: var(--smp-accent);
	color: #fff;
	box-shadow: 0 0.4em 1.2em color-mix(in srgb, var(--smp-accent) 35%, transparent);
}

.smp-btn-pulse-glow {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	animation: smp-lib-pulse-glow 2s ease-in-out infinite;
}

@keyframes smp-lib-pulse-glow {
	0%,
	100% {
		box-shadow: 0 0 0 0 color-mix(in srgb, var(--smp-accent) 55%, transparent);
	}
	50% {
		box-shadow: 0 0 0 0.65em transparent;
	}
}

.smp-btn-slide-up-bg {
	display: inline-flex;
	padding: 0.65em 1.25em;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	border: 2px solid var(--smp-accent);
	color: var(--smp-accent);
	background: transparent;
	z-index: 0;
}

.smp-btn-slide-up-bg::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--smp-accent);
	transform: translateY(100%);
	transition: transform var(--smp-duration-slow) var(--smp-ease);
	z-index: -1;
}

.smp-btn-slide-up-bg:hover::before,
.smp-btn-slide-up-bg:focus-visible::before {
	transform: translateY(0);
}

.smp-btn-slide-up-bg:hover,
.smp-btn-slide-up-bg:focus-visible {
	color: #fff;
}

.smp-btn-press-3d {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: linear-gradient(180deg, color-mix(in srgb, var(--smp-accent) 92%, #000) 0%, var(--smp-accent) 100%);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	box-shadow: 0 0.25em 0 color-mix(in srgb, var(--smp-accent) 55%, #000);
	transition: transform 0.08s ease, box-shadow 0.08s ease;
}

.smp-btn-press-3d:hover {
	transform: translateY(2px);
	box-shadow: 0 0.12em 0 color-mix(in srgb, var(--smp-accent) 55%, #000);
}

.smp-btn-press-3d:active {
	transform: translateY(4px);
	box-shadow: none;
}

.smp-btn-border-run {
	display: inline-flex;
	padding: 0.65em 1.25em;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	background: #fff;
	color: var(--smp-accent);
	border: 2px solid transparent;
	background-image: linear-gradient(#fff, #fff), linear-gradient(90deg, var(--smp-accent), var(--smp-accent-2), var(--smp-accent));
	background-origin: border-box;
	background-clip: padding-box, border-box;
	animation: smp-lib-border-spin 3s linear infinite;
}

@keyframes smp-lib-border-spin {
	to {
		filter: hue-rotate(360deg);
	}
}

.smp-btn-neon-edge {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: #0f172a;
	color: #e2e8f0;
	border: 2px solid var(--smp-accent);
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	box-shadow: 0 0 12px color-mix(in srgb, var(--smp-accent) 55%, transparent), inset 0 0 12px color-mix(in srgb, var(--smp-accent) 15%, transparent);
	transition: box-shadow var(--smp-duration) var(--smp-ease), text-shadow var(--smp-duration) var(--smp-ease);
}

.smp-btn-neon-edge:hover,
.smp-btn-neon-edge:focus-visible {
	box-shadow: 0 0 22px color-mix(in srgb, var(--smp-accent) 75%, transparent);
	text-shadow: 0 0 8px color-mix(in srgb, var(--smp-accent) 80%, transparent);
}

.smp-btn-stripe-slide {
	display: inline-flex;
	padding: 0.65em 1.25em;
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	background: repeating-linear-gradient(
		-45deg,
		var(--smp-accent),
		var(--smp-accent) 8px,
		var(--smp-accent-2) 8px,
		var(--smp-accent-2) 16px
	);
	background-size: 24px 24px;
	animation: smp-lib-stripe-move 4s linear infinite;
}

@keyframes smp-lib-stripe-move {
	to {
		background-position: 240px 0;
	}
}

.smp-btn-magnetic-soft {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-btn-magnetic-soft:hover,
.smp-btn-magnetic-soft:focus-visible {
	transform: scale(1.06);
}

.smp-btn-dual-tone {
	display: inline-flex;
	padding: 0.65em 1.25em;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	background: linear-gradient(120deg, var(--smp-accent) 0%, var(--smp-accent-2) 100%);
	color: #fff;
	transition: filter var(--smp-duration) var(--smp-ease), transform var(--smp-duration) var(--smp-ease);
}

.smp-btn-dual-tone:hover,
.smp-btn-dual-tone:focus-visible {
	filter: hue-rotate(25deg) brightness(1.05);
	transform: translateY(-2px);
}

.smp-btn-corner-accent {
	display: inline-flex;
	padding: 0.65em 1.25em;
	position: relative;
	background: color-mix(in srgb, var(--smp-accent) 12%, #fff);
	color: var(--smp-accent);
	border: 1px solid color-mix(in srgb, var(--smp-accent) 35%, transparent);
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
}

.smp-btn-corner-accent::before,
.smp-btn-corner-accent::after {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	border-color: var(--smp-accent-2);
	border-style: solid;
	transition: all var(--smp-duration) var(--smp-ease);
	opacity: 0;
}

.smp-btn-corner-accent::before {
	top: 4px;
	left: 4px;
	border-width: 2px 0 0 2px;
}

.smp-btn-corner-accent::after {
	bottom: 4px;
	right: 4px;
	border-width: 0 2px 2px 0;
}

.smp-btn-corner-accent:hover::before,
.smp-btn-corner-accent:hover::after,
.smp-btn-corner-accent:focus-visible::before,
.smp-btn-corner-accent:focus-visible::after {
	opacity: 1;
}

.smp-btn-breathe {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	animation: smp-lib-breathe 2.4s ease-in-out infinite;
}

@keyframes smp-lib-breathe {
	0%,
	100% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.04);
	}
}

.smp-btn-arrow-slide {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	padding: 0.65em 1.1em 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	border: none;
}

.smp-btn-arrow-slide::after {
	content: "→";
	display: inline-block;
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-btn-arrow-slide:hover::after,
.smp-btn-arrow-slide:focus-visible::after {
	transform: translateX(6px);
}

.smp-btn-invert-flash {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	transition: filter 0.12s ease;
}

.smp-btn-invert-flash:hover,
.smp-btn-invert-flash:focus-visible {
	filter: invert(1);
}

.smp-btn-ring-expand {
	display: inline-flex;
	padding: 0.65em 1.25em;
	position: relative;
	background: var(--smp-accent);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
}

.smp-btn-ring-expand::after {
	content: "";
	position: absolute;
	inset: -4px;
	border-radius: inherit;
	border: 2px solid var(--smp-accent-2);
	opacity: 0;
	transform: scale(0.85);
	transition: opacity var(--smp-duration) var(--smp-ease), transform var(--smp-duration) var(--smp-ease);
	pointer-events: none;
}

.smp-btn-ring-expand:hover::after,
.smp-btn-ring-expand:focus-visible::after {
	opacity: 1;
	transform: scale(1.08);
}

.smp-btn-skew-flat {
	display: inline-flex;
	padding: 0.65em 1.25em;
	background: var(--smp-accent);
	color: #fff;
	border: none;
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	transform: skewX(-6deg);
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-btn-skew-flat:hover,
.smp-btn-skew-flat:focus-visible {
	transform: skewX(0deg);
}

.smp-btn-glass-shine {
	display: inline-flex;
	padding: 0.65em 1.25em;
	position: relative;
	overflow: hidden;
	background: color-mix(in srgb, var(--smp-accent) 88%, #fff);
	color: #fff;
	border: 1px solid color-mix(in srgb, #fff 40%, transparent);
	border-radius: var(--smp-radius);
	text-decoration: none;
	cursor: pointer;
	backdrop-filter: blur(6px);
}

.smp-btn-glass-shine::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 40%, color-mix(in srgb, #fff 55%, transparent) 50%, transparent 60%);
	transform: translateX(-100%);
	transition: transform var(--smp-duration-slow) var(--smp-ease);
}

.smp-btn-glass-shine:hover::after,
.smp-btn-glass-shine:focus-visible::after {
	transform: translateX(100%);
}

/* ── Text / Überschriften ─────────────────────────────────────── */

.smp-txt-slide-left {
	animation: smp-lib-txt-sl 0.85s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-sl {
	from {
		opacity: 0;
		transform: translateX(-1.25rem);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.smp-txt-slide-right {
	animation: smp-lib-txt-sr 0.85s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-sr {
	from {
		opacity: 0;
		transform: translateX(1.25rem);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.smp-txt-zoom-enter {
	animation: smp-lib-txt-zoom 0.75s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-zoom {
	from {
		opacity: 0;
		transform: scale(0.92);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.smp-txt-flip-enter {
	animation: smp-lib-txt-flip 0.9s var(--smp-ease-out) both;
	transform-style: preserve-3d;
}

@keyframes smp-lib-txt-flip {
	from {
		opacity: 0;
		transform: perspective(500px) rotateX(-78deg);
	}
	to {
		opacity: 1;
		transform: perspective(500px) rotateX(0);
	}
}

.smp-txt-gradient-flow {
	background: linear-gradient(90deg, var(--smp-accent), var(--smp-accent-2), var(--smp-accent));
	background-size: 200% auto;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	animation: smp-lib-grad-flow 4s linear infinite;
}

@keyframes smp-lib-grad-flow {
	to {
		background-position: 200% center;
	}
}

.smp-txt-letter-open {
	animation: smp-lib-letter 1s var(--smp-ease-out) both;
}

@keyframes smp-lib-letter {
	from {
		opacity: 0;
		letter-spacing: -0.08em;
	}
	to {
		opacity: 1;
		letter-spacing: normal;
	}
}

.smp-txt-shadow-pulse {
	animation: smp-lib-txt-sh 2.2s ease-in-out infinite;
}

@keyframes smp-lib-txt-sh {
	0%,
	100% {
		text-shadow: 0 0 0 transparent;
	}
	50% {
		text-shadow: 0 0.15em 0.35em color-mix(in srgb, var(--smp-accent) 45%, transparent);
	}
}

.smp-txt-skew-enter {
	animation: smp-lib-txt-sk 0.8s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-sk {
	from {
		opacity: 0;
		transform: skewX(-8deg) translateY(0.4rem);
	}
	to {
		opacity: 1;
		transform: skewX(0) translateY(0);
	}
}

.smp-txt-pop-enter {
	animation: smp-lib-txt-pop 0.65s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes smp-lib-txt-pop {
	from {
		opacity: 0;
		transform: scale(0.5);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.smp-txt-underline-sweep {
	position: relative;
	display: inline-block;
}

.smp-txt-underline-sweep::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 2px;
	background: var(--smp-accent);
	transform: scaleX(0);
	transform-origin: left;
	animation: smp-lib-ul-sweep 1s var(--smp-ease-out) 0.3s forwards;
}

@keyframes smp-lib-ul-sweep {
	to {
		transform: scaleX(1);
	}
}

.smp-txt-highlight-sweep {
	position: relative;
	display: inline-block;
}

.smp-txt-highlight-sweep::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0.1em;
	height: 0.38em;
	background: color-mix(in srgb, var(--smp-accent-2) 35%, transparent);
	z-index: -1;
	transform: scaleX(0);
	transform-origin: left;
	animation: smp-lib-hi-sweep 0.9s var(--smp-ease-out) 0.2s forwards;
}

@keyframes smp-lib-hi-sweep {
	to {
		transform: scaleX(1);
	}
}

.smp-txt-bounce-enter {
	animation: smp-lib-txt-bnce 0.85s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes smp-lib-txt-bnce {
	0% {
		opacity: 0;
		transform: translateY(2rem);
	}
	60% {
		opacity: 1;
		transform: translateY(-0.35rem);
	}
	100% {
		transform: translateY(0);
	}
}

.smp-txt-rotate-enter {
	animation: smp-lib-txt-rot 0.85s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-rot {
	from {
		opacity: 0;
		transform: rotate(-8deg) translateY(0.5rem);
	}
	to {
		opacity: 1;
		transform: rotate(0) translateY(0);
	}
}

.smp-txt-blur-strong-in {
	animation: smp-lib-txt-blur-h 1s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-blur-h {
	from {
		opacity: 0;
		filter: blur(16px);
	}
	to {
		opacity: 1;
		filter: blur(0);
	}
}

.smp-txt-mask-up {
	animation: smp-lib-mask-up 1s var(--smp-ease-out) both;
}

@keyframes smp-lib-mask-up {
	from {
		opacity: 0;
		clip-path: inset(100% 0 0 0);
	}
	to {
		opacity: 1;
		clip-path: inset(0 0 0 0);
	}
}

.smp-txt-scale-soft-in {
	animation: smp-lib-txt-sc 0.9s var(--smp-ease-out) both;
}

@keyframes smp-lib-txt-sc {
	from {
		opacity: 0;
		transform: scale(0.96);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.smp-txt-stamp-in {
	animation: smp-lib-stamp 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes smp-lib-stamp {
	from {
		opacity: 0;
		transform: scale(1.35);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

/* ── Boxen & Bewegung ─────────────────────────────────────────── */

.smp-box-tilt-hover {
	transition: transform var(--smp-duration) var(--smp-ease);
	transform-style: preserve-3d;
}

.smp-box-tilt-hover:hover {
	transform: perspective(420px) rotateX(4deg) rotateY(-6deg);
}

.smp-box-wobble {
	animation: smp-lib-wobble 2.5s ease-in-out infinite;
}

@keyframes smp-lib-wobble {
	0%,
	100% {
		transform: rotate(0deg);
	}
	25% {
		transform: rotate(-2deg);
	}
	75% {
		transform: rotate(2deg);
	}
}

.smp-box-heartbeat {
	animation: smp-lib-heart 1.4s ease-in-out infinite;
}

@keyframes smp-lib-heart {
	0%,
	100% {
		transform: scale(1);
	}
	20% {
		transform: scale(1.08);
	}
	40% {
		transform: scale(1);
	}
	60% {
		transform: scale(1.05);
	}
}

.smp-box-shake-min:hover {
	animation: smp-lib-shake 0.45s ease;
}

@keyframes smp-lib-shake {
	0%,
	100% {
		transform: translateX(0);
	}
	25% {
		transform: translateX(-3px);
	}
	75% {
		transform: translateX(3px);
	}
}

.smp-box-spin-slow {
	display: inline-block;
	animation: smp-lib-spin 8s linear infinite;
}

@keyframes smp-lib-spin {
	to {
		transform: rotate(360deg);
	}
}

.smp-box-jelly:hover {
	animation: smp-lib-jelly 0.65s ease;
}

@keyframes smp-lib-jelly {
	0%,
	100% {
		transform: scale(1, 1);
	}
	30% {
		transform: scale(1.12, 0.88);
	}
	50% {
		transform: scale(0.92, 1.08);
	}
	70% {
		transform: scale(1.05, 0.95);
	}
}

.smp-box-ping-dot {
	position: relative;
	display: inline-flex;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--smp-accent);
}

.smp-box-ping-dot::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: var(--smp-accent);
	animation: smp-lib-ping 1.6s ease-out infinite;
	opacity: 0.6;
}

@keyframes smp-lib-ping {
	0% {
		transform: scale(1);
		opacity: 0.6;
	}
	100% {
		transform: scale(2.8);
		opacity: 0;
	}
}

.smp-box-swing {
	animation: smp-lib-swing 2.8s ease-in-out infinite;
	transform-origin: top center;
}

@keyframes smp-lib-swing {
	0%,
	100% {
		transform: rotate(0deg);
	}
	25% {
		transform: rotate(4deg);
	}
	75% {
		transform: rotate(-4deg);
	}
}

.smp-box-rubber:hover {
	animation: smp-lib-rubber 0.75s ease;
}

@keyframes smp-lib-rubber {
	0% {
		transform: scale(1);
	}
	35% {
		transform: scale(1.12, 0.9);
	}
	55% {
		transform: scale(0.94, 1.06);
	}
	75% {
		transform: scale(1.04, 0.98);
	}
	100% {
		transform: scale(1);
	}
}

.smp-box-grow-hover {
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-box-grow-hover:hover {
	transform: scale(1.08);
}

.smp-box-shrink-hover {
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-box-shrink-hover:hover {
	transform: scale(0.94);
}

.smp-box-glow-outline {
	transition: box-shadow var(--smp-duration) var(--smp-ease);
	border-radius: var(--smp-radius);
}

.smp-box-glow-outline:hover {
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--smp-accent) 45%, transparent), 0 0.5em 1.5em color-mix(in srgb, var(--smp-accent) 25%, transparent);
}

.smp-box-lift-soft {
	transition: transform var(--smp-duration) var(--smp-ease), box-shadow var(--smp-duration) var(--smp-ease);
	border-radius: var(--smp-radius);
}

.smp-box-lift-soft:hover {
	transform: translateY(-4px);
	box-shadow: 0 0.75em 1.8em rgba(0, 0, 0, 0.12);
}

.smp-box-skew-hover {
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-box-skew-hover:hover {
	transform: skewX(-3deg);
}

.smp-box-bounce-in-once {
	animation: smp-lib-box-bnce 0.85s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes smp-lib-box-bnce {
	0% {
		opacity: 0;
		transform: scale(0.3) translateY(2rem);
	}
	60% {
		opacity: 1;
		transform: scale(1.05) translateY(-0.25rem);
	}
	100% {
		transform: scale(1) translateY(0);
	}
}

.smp-box-flip-hover {
	transition: transform var(--smp-duration-slow) var(--smp-ease);
	transform-style: preserve-3d;
}

.smp-box-flip-hover:hover {
	transform: rotateY(12deg);
}

.smp-box-slide-nudge {
	animation: smp-lib-nudge 2.2s ease-in-out infinite;
}

@keyframes smp-lib-nudge {
	0%,
	100% {
		transform: translateX(0);
	}
	50% {
		transform: translateX(6px);
	}
}

.smp-box-shadow-pulse {
	animation: smp-lib-sh-pulse 2.4s ease-in-out infinite;
	border-radius: var(--smp-radius);
}

@keyframes smp-lib-sh-pulse {
	0%,
	100% {
		box-shadow: 0 0.2em 0.6em rgba(0, 0, 0, 0.08);
	}
	50% {
		box-shadow: 0 0.5em 1.2em color-mix(in srgb, var(--smp-accent) 30%, transparent);
	}
}

/* ── Trenner & Linien (zusätzlich) ───────────────────────────── */

.smp-ln-dot-flow {
	border: none;
	height: 3px;
	background: repeating-linear-gradient(90deg, var(--smp-accent) 0 4px, transparent 4px 10px);
	background-size: 200% 100%;
	animation: smp-lib-dots 2.5s linear infinite;
}

@keyframes smp-lib-dots {
	to {
		background-position: 200% 0;
	}
}

.smp-ln-dash-animate {
	border: none;
	height: 2px;
	background: repeating-linear-gradient(90deg, var(--smp-accent) 0 12px, transparent 12px 20px);
	background-size: 200% 100%;
	animation: smp-lib-dots 3s linear infinite;
}

.smp-ln-double-soft {
	border: none;
	height: 6px;
	background: linear-gradient(transparent 2px, var(--smp-accent) 2px, var(--smp-accent) 3px, transparent 3px, transparent 5px, var(--smp-accent-2) 5px, var(--smp-accent-2) 6px);
	opacity: 0.85;
}

.smp-ln-arrow-wrap {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--smp-accent), transparent);
	position: relative;
}

.smp-ln-arrow-wrap::after {
	content: "▲";
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -55%) rotate(90deg);
	font-size: 10px;
	color: var(--smp-accent);
}

.smp-ln-spin-grad {
	display: block;
	height: 4px;
	border-radius: 999px;
	background: conic-gradient(from 0deg, var(--smp-accent), var(--smp-accent-2), var(--smp-accent));
	animation: smp-lib-spin 4s linear infinite;
}

.smp-ln-zigzag-soft {
	border: none;
	height: 8px;
	background: linear-gradient(135deg, var(--smp-accent) 25%, transparent 25%) 0 0 / 12px 12px,
		linear-gradient(-135deg, var(--smp-accent) 25%, transparent 25%) 6px 0 / 12px 12px;
	opacity: 0.7;
}

.smp-ln-segment {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, var(--smp-accent) 0 18%, transparent 18% 28%, var(--smp-accent-2) 28% 48%, transparent 48% 58%, var(--smp-accent) 58% 100%);
}

.smp-ln-thick-pulse {
	display: block;
	height: 4px;
	border-radius: 2px;
	background: var(--smp-accent);
	animation: smp-lib-th-pulse 1.8s ease-in-out infinite;
}

@keyframes smp-lib-th-pulse {
	0%,
	100% {
		transform: scaleY(1);
		opacity: 1;
	}
	50% {
		transform: scaleY(1.6);
		opacity: 0.75;
	}
}

.smp-ln-orbit-dot {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, transparent 45%, var(--smp-accent) 45% 55%, transparent 55%);
	position: relative;
	overflow: visible;
}

.smp-ln-orbit-dot::before {
	content: "";
	position: absolute;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--smp-accent-2);
	left: 0;
	top: 50%;
	margin-top: -4px;
	animation: smp-lib-orbit 2.5s ease-in-out infinite;
}

@keyframes smp-lib-orbit {
	0%,
	100% {
		left: 0;
	}
	50% {
		left: calc(100% - 8px);
	}
}

.smp-ln-brackets-soft {
	border: none;
	height: 0;
	padding: 8px 0 0;
	position: relative;
	text-align: center;
}

.smp-ln-brackets-soft::before,
.smp-ln-brackets-soft::after {
	content: "";
	position: absolute;
	top: 0;
	width: 22%;
	height: 2px;
	background: var(--smp-accent);
}

.smp-ln-brackets-soft::before {
	left: 10%;
}
.smp-ln-brackets-soft::after {
	right: 10%;
}

.smp-ln-glow-line {
	display: block;
	height: 3px;
	border-radius: 999px;
	background: var(--smp-accent);
	box-shadow: 0 0 14px color-mix(in srgb, var(--smp-accent) 65%, transparent);
	animation: smp-lib-glow-line 2s ease-in-out infinite alternate;
}

@keyframes smp-lib-glow-line {
	from {
		filter: brightness(1);
	}
	to {
		filter: brightness(1.25);
	}
}

.smp-ln-offset-pair {
	border: none;
	height: 10px;
	background: linear-gradient(var(--smp-accent) 2px, transparent 2px), linear-gradient(transparent 6px, var(--smp-accent-2) 6px, var(--smp-accent-2) 8px, transparent 8px);
	background-repeat: no-repeat;
	background-size: 92% 100%, 88% 100%;
	background-position: center 0, center 0;
}

.smp-ln-star-mid {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--smp-accent), transparent);
	position: relative;
}

.smp-ln-star-mid::after {
	content: "✦";
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	color: var(--smp-accent-2);
	font-size: 14px;
	line-height: 1;
}

.smp-ln-fade-side {
	border: none;
	height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--smp-accent) 35%, var(--smp-accent) 65%, transparent 100%);
}

.smp-ln-hue-shift {
	display: block;
	height: 3px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--smp-accent), var(--smp-accent-2));
	animation: smp-lib-hue 5s linear infinite;
}

@keyframes smp-lib-hue {
	to {
		filter: hue-rotate(360deg);
	}
}

.smp-ln-diamond-cut {
	border: none;
	height: 12px;
	background: linear-gradient(135deg, var(--smp-accent) 12.5%, transparent 12.5%) 0 0 / 24px 24px;
	opacity: 0.65;
}

.smp-ln-wavy-soft {
	border: none;
	height: 6px;
	background: radial-gradient(circle at 10px 3px, var(--smp-accent) 2px, transparent 2px) 0 0 / 20px 8px repeat-x;
}

/* ── Links (zusätzlich zu smp-link-underline) ─────────────────── */

.smp-lnk-bg-wipe {
	position: relative;
	text-decoration: none;
	color: inherit;
	padding: 0.1em 0.2em;
}

.smp-lnk-bg-wipe::before {
	content: "";
	position: absolute;
	inset: 0;
	background: color-mix(in srgb, var(--smp-accent) 22%, transparent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--smp-duration) var(--smp-ease);
	z-index: -1;
	border-radius: 2px;
}

.smp-lnk-bg-wipe:hover::before,
.smp-lnk-bg-wipe:focus-visible::before {
	transform: scaleX(1);
}

.smp-lnk-grow-line {
	text-decoration: none;
	color: inherit;
	background-image: linear-gradient(var(--smp-accent), var(--smp-accent));
	background-position: 0 100%;
	background-repeat: no-repeat;
	background-size: 0% 2px;
	transition: background-size var(--smp-duration-slow) var(--smp-ease);
}

.smp-lnk-grow-line:hover,
.smp-lnk-grow-line:focus-visible {
	background-size: 100% 2px;
}

.smp-lnk-brackets-anim {
	text-decoration: none;
	color: inherit;
	position: relative;
}

.smp-lnk-brackets-anim::before,
.smp-lnk-brackets-anim::after {
	opacity: 0;
	transition: opacity var(--smp-duration) var(--smp-ease), transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-brackets-anim::before {
	content: "[";
	margin-right: 0.15em;
}
.smp-lnk-brackets-anim::after {
	content: "]";
	margin-left: 0.15em;
}

.smp-lnk-brackets-anim:hover::before,
.smp-lnk-brackets-anim:hover::after,
.smp-lnk-brackets-anim:focus-visible::before,
.smp-lnk-brackets-anim:focus-visible::after {
	opacity: 1;
}

.smp-lnk-arrow-flow {
	text-decoration: none;
	color: var(--smp-accent);
	display: inline-flex;
	align-items: center;
	gap: 0.25em;
}

.smp-lnk-arrow-flow::after {
	content: "→";
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-arrow-flow:hover::after,
.smp-lnk-arrow-flow:focus-visible::after {
	transform: translateX(5px);
}

.smp-lnk-text-glow {
	text-decoration: none;
	color: var(--smp-accent);
	transition: text-shadow var(--smp-duration) var(--smp-ease);
}

.smp-lnk-text-glow:hover,
.smp-lnk-text-glow:focus-visible {
	text-shadow: 0 0 12px color-mix(in srgb, var(--smp-accent) 65%, transparent);
}

.smp-lnk-strike-open {
	text-decoration: none;
	color: inherit;
	position: relative;
}

.smp-lnk-strike-open::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	height: 2px;
	background: var(--smp-accent);
	transform: scaleX(0);
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-strike-open:hover::after,
.smp-lnk-strike-open:focus-visible::after {
	transform: scaleX(1);
}

.smp-lnk-dotline {
	text-decoration: none;
	color: inherit;
	border-bottom: 2px dotted var(--smp-accent);
	transition: border-color var(--smp-duration) var(--smp-ease);
}

.smp-lnk-dotline:hover,
.smp-lnk-dotline:focus-visible {
	border-bottom-color: var(--smp-accent-2);
}

.smp-lnk-double-anim {
	text-decoration: none;
	color: inherit;
	box-shadow: 0 2px 0 var(--smp-accent), 0 5px 0 var(--smp-accent-2);
	transition: box-shadow var(--smp-duration) var(--smp-ease), transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-double-anim:hover,
.smp-lnk-double-anim:focus-visible {
	transform: translateY(-2px);
	box-shadow: 0 3px 0 var(--smp-accent), 0 7px 0 var(--smp-accent-2);
}

.smp-lnk-slide-em {
	text-decoration: none;
	color: inherit;
	position: relative;
}

.smp-lnk-slide-em::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	width: 100%;
	height: 3px;
	background: var(--smp-accent);
	transform: translateX(-100%);
	transition: transform var(--smp-duration-slow) var(--smp-ease);
}

.smp-lnk-slide-em:hover::after,
.smp-lnk-slide-em:focus-visible::after {
	transform: translateX(0);
}

.smp-lnk-chevron-hop {
	text-decoration: none;
	color: var(--smp-accent);
}

.smp-lnk-chevron-hop::after {
	content: " ›";
	display: inline-block;
	animation: smp-lib-hop 1s ease-in-out infinite;
}

@keyframes smp-lib-hop {
	0%,
	100% {
		transform: translateX(0);
	}
	50% {
		transform: translateX(4px);
	}
}

.smp-lnk-sweep-color {
	text-decoration: none;
	background: linear-gradient(90deg, var(--smp-accent), var(--smp-accent-2), var(--smp-accent));
	background-size: 200% auto;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	animation: smp-lib-grad-flow 5s linear infinite;
}

.smp-lnk-pad-pop {
	text-decoration: none;
	color: inherit;
	padding: 0.15em 0.35em;
	border-radius: 4px;
	transition: padding var(--smp-duration) var(--smp-ease), background var(--smp-duration) var(--smp-ease);
}

.smp-lnk-pad-pop:hover,
.smp-lnk-pad-pop:focus-visible {
	padding: 0.25em 0.55em;
	background: color-mix(in srgb, var(--smp-accent) 15%, transparent);
}

.smp-lnk-corner-flash {
	text-decoration: none;
	color: inherit;
	position: relative;
}

.smp-lnk-corner-flash::before {
	content: "";
	position: absolute;
	inset: -2px;
	border: 2px solid transparent;
	border-radius: 4px;
	transition: border-color 0.1s ease;
}

.smp-lnk-corner-flash:hover::before,
.smp-lnk-corner-flash:focus-visible::before {
	border-color: var(--smp-accent);
	animation: smp-lib-corner-fl 0.5s ease;
}

@keyframes smp-lib-corner-fl {
	0% {
		opacity: 0;
	}
	40% {
		opacity: 1;
	}
	100% {
		opacity: 0.6;
	}
}

.smp-lnk-wave-line {
	text-decoration: underline;
	text-decoration-style: wavy;
	text-decoration-color: var(--smp-accent);
	text-underline-offset: 5px;
	color: inherit;
	transition: text-decoration-color var(--smp-duration) var(--smp-ease);
}

.smp-lnk-wave-line:hover,
.smp-lnk-wave-line:focus-visible {
	text-decoration-color: var(--smp-accent-2);
}

.smp-lnk-weight-pop {
	text-decoration: none;
	color: inherit;
	font-weight: 400;
	transition: font-weight 0.12s ease;
}

.smp-lnk-weight-pop:hover,
.smp-lnk-weight-pop:focus-visible {
	font-weight: 700;
}

.smp-lnk-split-color {
	text-decoration: none;
	background: linear-gradient(90deg, var(--smp-accent) 50%, var(--smp-accent-2) 50%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.smp-lnk-tilt-hover {
	text-decoration: none;
	color: inherit;
	display: inline-block;
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-tilt-hover:hover,
.smp-lnk-tilt-hover:focus-visible {
	transform: rotate(-2deg);
}

.smp-lnk-outline-glow {
	text-decoration: none;
	color: var(--smp-accent);
	padding: 0.1em 0.25em;
	border-radius: 4px;
	border: 1px solid transparent;
	transition: border-color var(--smp-duration) var(--smp-ease), box-shadow var(--smp-duration) var(--smp-ease);
}

.smp-lnk-outline-glow:hover,
.smp-lnk-outline-glow:focus-visible {
	border-color: var(--smp-accent);
	box-shadow: 0 0 10px color-mix(in srgb, var(--smp-accent) 40%, transparent);
}

.smp-lnk-mirror-hover {
	text-decoration: none;
	color: inherit;
	display: inline-block;
	transition: transform var(--smp-duration) var(--smp-ease);
}

.smp-lnk-mirror-hover:hover,
.smp-lnk-mirror-hover:focus-visible {
	transform: scaleX(-1);
}
