/* ============================================================
   DONAT Suite – Hero Slider Widget
   ============================================================ */

.elementor-widget-des_hero_slider,
.elementor-widget-des_hero_slider > .elementor-widget-container {
	height: 100%;
}

.des-hero-slider {
	--des-hs-height: 100%;
	--des-hs-min-height: 480px;
	--des-hs-duration: 650ms;
	--des-hs-content-duration: 550ms;
	--des-hs-content-start-delay: 140ms;
	--des-hs-button-delay: 120ms;

	--des-hs-fallback-bg: #111111;
	--des-hs-overlay-bg: rgba(0, 0, 0, 0.2);
	--des-hs-image-position: center center;

	--des-hs-content-padding: 60px;
	--des-hs-content-v-align: center;
	--des-hs-content-h-align: flex-start;
	--des-hs-copy-max-width: 760px;
	--des-hs-copy-text-align: left;

	--des-hs-bubble-bg: #d80f2f;
	--des-hs-bubble-padding: 22px 28px 24px;
	--des-hs-bubble-radius: 10px;
	--des-hs-bubble-tail-size: 32px;
	--des-hs-bubble-tail-position: 88%;
	--des-hs-eyebrow-color: #ffffff;
	--des-hs-eyebrow-margin-bottom: 6px;

	--des-hs-title-color: #ffffff;
	--des-hs-title-bg: rgba(0, 0, 0, 0.78);
	--des-hs-title-padding: 4px 12px;
	--des-hs-title-radius: 6px;
	--des-hs-title-margin-bottom: 22px;

	--des-hs-button-color: #ffffff;
	--des-hs-button-bg: #111111;
	--des-hs-button-color-hover: #111111;
	--des-hs-button-bg-hover: #ffffff;
	--des-hs-button-padding: 12px 22px;
	--des-hs-button-radius: 999px;

	--des-hs-arrow-color: #ffffff;
	--des-hs-arrow-bg: rgba(0, 0, 0, 0.35);
	--des-hs-arrow-size: 46px;
	--des-hs-arrow-offset: 24px;
	--des-hs-arrow-radius: 999px;

	--des-hs-dot-color: rgba(255, 255, 255, 0.55);
	--des-hs-dot-active-color: #ffffff;

	position: relative;
	width: 100%;
	height: var(--des-hs-height);
	min-height: var(--des-hs-min-height);
	overflow: hidden;
	isolation: isolate;
	background: var(--des-hs-fallback-bg);
	color: #fff;
}

.des-hero-slider,
.des-hero-slider * {
	box-sizing: border-box;
}

.des-hs-slides,
.des-hs-slide,
.des-hs-media,
.des-hs-overlay,
.des-hs-content {
	position: absolute;
	inset: 0;
}

.des-hs-slides {
	z-index: 1;
}

.des-hs-slide {
	opacity: 0;
	visibility: hidden;
	z-index: 1;
	overflow: hidden;
	pointer-events: none;
	transition:
		opacity var(--des-hs-duration) ease,
		visibility var(--des-hs-duration) ease,
		transform var(--des-hs-duration) ease;
}

.des-hs-slide.is-active {
	opacity: 1;
	visibility: visible;
	z-index: 2;
	pointer-events: auto;
}

.des-hs-media {
	z-index: 1;
	background: inherit;
}

.des-hs-image {
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	object-position: var(--des-hs-image-position) !important;
}

.des-hs-image-fallback {
	background:
		radial-gradient(circle at 25% 20%, rgba(255, 255, 255, 0.18), transparent 34%),
		linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.24));
}

.des-hs-overlay {
	z-index: 2;
	background: var(--des-hs-overlay-bg);
	pointer-events: none;
}

.des-hs-content {
	z-index: 3;
	display: flex;
	flex-direction: column;
	justify-content: var(--des-hs-content-v-align);
	align-items: var(--des-hs-content-h-align);
	padding: var(--des-hs-content-padding);
	pointer-events: none;
}

.des-hs-copy {
	width: 100%;
	max-width: var(--des-hs-copy-max-width);
	text-align: var(--des-hs-copy-text-align);
	pointer-events: auto;
}

.des-hs-bubble {
	display: inline-flex;
	max-width: 100%;
	flex-direction: column;
	align-items: flex-start;
	position: relative;
}

.des-hs-panel-bubble .des-hs-bubble,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-bubble {
	background: var(--des-hs-bubble-bg);
	border-radius: var(--des-hs-bubble-radius);
	padding: var(--des-hs-bubble-padding);
	color: var(--des-hs-title-color);
}

.des-hs-panel-bubble .des-hs-bubble::after,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-bubble::after {
	content: "";
	position: absolute;
	left: var(--des-hs-bubble-tail-position);
	bottom: calc(var(--des-hs-bubble-tail-size) * -0.92);
	width: var(--des-hs-bubble-tail-size);
	height: var(--des-hs-bubble-tail-size);
	background: var(--des-hs-bubble-bg);
	clip-path: polygon(0 0, 100% 0, 100% 100%);
	transform: translateX(-50%);
	pointer-events: none;
}

.des-hs-panel-bubble .des-hs-eyebrow,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-eyebrow {
	margin: 0 0 var(--des-hs-eyebrow-margin-bottom);
	padding: 0;
	color: var(--des-hs-eyebrow-color);
	font-size: 0.86em;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.1;
	text-transform: uppercase;
}

.des-hs-panel-bubble .des-hs-title-text,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-title-text {
	background: transparent !important;
	border-radius: 0 !important;
	padding: 0 !important;
	line-height: 1.08;
}

.des-hs-panel-bubble .des-hs-title,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-title {
	line-height: 1.08;
}

.des-hs-panel-bubble .des-hs-button,
.des-hs-widget-panel-bubble .des-hero-slider .des-hs-button {
	align-self: flex-start;
}

.des-hs-title {
	margin: 0 0 var(--des-hs-title-margin-bottom);
	padding: 0;
	color: inherit;
	line-height: 1.12;
}

.des-hs-title-text {
	display: inline;
	color: var(--des-hs-title-color);
	background-color: var(--des-hs-title-bg);
	padding: var(--des-hs-title-padding);
	border-radius: var(--des-hs-title-radius);
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	line-height: 1.28;
}

.des-hs-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45em;
	color: var(--des-hs-button-color);
	background: var(--des-hs-button-bg);
	border: 0 solid transparent;
	border-radius: var(--des-hs-button-radius);
	padding: var(--des-hs-button-padding);
	text-decoration: none;
	line-height: 1.2;
	transition:
		color 180ms ease,
		background-color 180ms ease,
		border-color 180ms ease,
		transform 180ms ease;
}

.des-hs-button:hover,
.des-hs-button:focus-visible {
	color: var(--des-hs-button-color-hover);
	background: var(--des-hs-button-bg-hover);
	text-decoration: none;
	transform: translateY(-1px);
}

.des-hs-button:focus-visible,
.des-hs-arrow:focus-visible,
.des-hs-dot:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

/* Slide effects */
.des-hs-effect-fade .des-hs-slide,
.des-hs-widget-effect-fade .des-hero-slider .des-hs-slide {
	transform: translate3d(0, 0, 0);
}

.des-hs-effect-fade .des-hs-slide.is-entering,
.des-hs-effect-fade .des-hs-slide.is-leaving,
.des-hs-widget-effect-fade .des-hero-slider .des-hs-slide.is-entering,
.des-hs-widget-effect-fade .des-hero-slider .des-hs-slide.is-leaving {
	visibility: visible;
}

.des-hs-effect-slide .des-hs-slide,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide {
	transform: translate3d(100%, 0, 0);
}

.des-hs-effect-slide .des-hs-slide.is-active,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide.is-active {
	transform: translate3d(0, 0, 0);
}

.des-hs-effect-slide .des-hs-slide.is-entering,
.des-hs-effect-slide .des-hs-slide.is-leaving,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide.is-entering,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide.is-leaving {
	opacity: 1;
	visibility: visible;
}

.des-hs-effect-slide .des-hs-slide.is-entering,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide.is-entering {
	z-index: 3;
}

.des-hs-effect-slide .des-hs-slide.is-leaving,
.des-hs-widget-effect-slide .des-hero-slider .des-hs-slide.is-leaving {
	z-index: 2;
}

.des-hs-effect-slide.des-hs-dir-next .des-hs-slide.is-entering,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-next .des-hs-slide.is-entering {
	transform: translate3d(100%, 0, 0);
}

.des-hs-effect-slide.des-hs-dir-prev .des-hs-slide.is-entering,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-prev .des-hs-slide.is-entering {
	transform: translate3d(-100%, 0, 0);
}

.des-hs-effect-slide.des-hs-dir-next .des-hs-slide.is-entering.is-active,
.des-hs-effect-slide.des-hs-dir-prev .des-hs-slide.is-entering.is-active,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-next .des-hs-slide.is-entering.is-active,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-prev .des-hs-slide.is-entering.is-active {
	transform: translate3d(0, 0, 0);
}

.des-hs-effect-slide.des-hs-dir-next .des-hs-slide.is-leaving,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-next .des-hs-slide.is-leaving {
	transform: translate3d(-100%, 0, 0);
}

.des-hs-effect-slide.des-hs-dir-prev .des-hs-slide.is-leaving,
.des-hs-widget-effect-slide .des-hero-slider.des-hs-dir-prev .des-hs-slide.is-leaving {
	transform: translate3d(100%, 0, 0);
}

/* Content animations */
@keyframes desHsContentFade {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@keyframes desHsContentSlideUp {
	from {
		opacity: 0;
		transform: translate3d(0, 24px, 0);
	}

	to {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}
}

@keyframes desHsContentSlideDown {
	from {
		opacity: 0;
		transform: translate3d(0, -24px, 0);
	}

	to {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}
}

@keyframes desHsContentZoom {
	from {
		opacity: 0;
		transform: scale(0.96);
	}

	to {
		opacity: 1;
		transform: scale(1);
	}
}

.des-hs-eyebrow,
.des-hs-title,
.des-hs-button {
	will-change: opacity, transform;
}

/*
 * Titel/Button sind erst unsichtbar, sobald das JS bereit ist.
 * Ohne JS bleibt der aktive erste Slide dadurch sauber sichtbar.
 */
.des-hs-slide:not(.is-active) .des-hs-eyebrow,
.des-hs-slide:not(.is-active) .des-hs-title,
.des-hs-slide:not(.is-active) .des-hs-button,
.des-hero-slider.des-hs-animations-ready .des-hs-slide .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready .des-hs-slide .des-hs-title,
.des-hero-slider.des-hs-animations-ready .des-hs-slide .des-hs-button {
	animation: none;
	opacity: 0;
	transform: none;
}

.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title,
.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-duration: var(--des-hs-content-duration);
	animation-fill-mode: both;
	animation-timing-function: ease;
	opacity: 1;
}

.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation-delay: 0ms;
}

.des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-delay: var(--des-hs-button-delay);
}

/* Titel-Animationen */
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-none .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-none .des-hs-slide.is-content-ready .des-hs-title,
.des-hs-widget-title-anim-none .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hs-widget-title-anim-none .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation: none;
	opacity: 1;
	transform: none;
}

.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-fade .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-fade .des-hs-slide.is-content-ready .des-hs-title,
.des-hs-widget-title-anim-fade .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hs-widget-title-anim-fade .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation-name: desHsContentFade;
}

.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-slide_up .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-slide_up .des-hs-slide.is-content-ready .des-hs-title,
.des-hs-widget-title-anim-slide_up .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hs-widget-title-anim-slide_up .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation-name: desHsContentSlideUp;
}

.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-slide_down .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-slide_down .des-hs-slide.is-content-ready .des-hs-title,
.des-hs-widget-title-anim-slide_down .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hs-widget-title-anim-slide_down .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation-name: desHsContentSlideDown;
}

.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-zoom .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hero-slider.des-hs-animations-ready.des-hs-title-anim-zoom .des-hs-slide.is-content-ready .des-hs-title,
.des-hs-widget-title-anim-zoom .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-eyebrow,
.des-hs-widget-title-anim-zoom .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-title {
	animation-name: desHsContentZoom;
}

/* Button-Animationen */
.des-hero-slider.des-hs-animations-ready.des-hs-button-anim-none .des-hs-slide.is-content-ready .des-hs-button,
.des-hs-widget-button-anim-none .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation: none;
	opacity: 1;
	transform: none;
}

.des-hero-slider.des-hs-animations-ready.des-hs-button-anim-fade .des-hs-slide.is-content-ready .des-hs-button,
.des-hs-widget-button-anim-fade .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-name: desHsContentFade;
}

.des-hero-slider.des-hs-animations-ready.des-hs-button-anim-slide_up .des-hs-slide.is-content-ready .des-hs-button,
.des-hs-widget-button-anim-slide_up .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-name: desHsContentSlideUp;
}

.des-hero-slider.des-hs-animations-ready.des-hs-button-anim-slide_down .des-hs-slide.is-content-ready .des-hs-button,
.des-hs-widget-button-anim-slide_down .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-name: desHsContentSlideDown;
}

.des-hero-slider.des-hs-animations-ready.des-hs-button-anim-zoom .des-hs-slide.is-content-ready .des-hs-button,
.des-hs-widget-button-anim-zoom .des-hero-slider.des-hs-animations-ready .des-hs-slide.is-content-ready .des-hs-button {
	animation-name: desHsContentZoom;
}

/* Arrows */
.des-hs-arrow {
	position: absolute;
	top: 50%;
	z-index: 5;
	width: var(--des-hs-arrow-size);
	height: var(--des-hs-arrow-size);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: 0;
	border-radius: var(--des-hs-arrow-radius);
	color: var(--des-hs-arrow-color);
	background: var(--des-hs-arrow-bg);
	font: inherit;
	font-size: calc(var(--des-hs-arrow-size) * 0.55);
	line-height: 1;
	cursor: pointer;
	transform: translateY(-50%);
	transition:
		background-color 180ms ease,
		color 180ms ease,
		transform 180ms ease,
		opacity 180ms ease;
}

.des-hs-arrow:hover {
	transform: translateY(-50%) scale(1.04);
}

.des-hs-arrow-prev {
	left: var(--des-hs-arrow-offset);
}

.des-hs-arrow-next {
	right: var(--des-hs-arrow-offset);
}

/* Dots */
.des-hs-dots {
	position: absolute;
	z-index: 5;
	left: 50%;
	bottom: 22px;
	display: flex;
	gap: 9px;
	transform: translateX(-50%);
}

.des-hs-dot {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: var(--des-hs-dot-color);
	cursor: pointer;
	transition:
		width 180ms ease,
		background-color 180ms ease,
		opacity 180ms ease;
}

.des-hs-dot.is-active {
	width: 28px;
	background: var(--des-hs-dot-active-color);
}

/* Editor / fallback */
.des-hs-editor-notice {
	min-height: var(--des-hs-min-height, 320px);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
	text-align: center;
	color: #777;
	background: #f7f7f7;
	border: 2px dashed #ddd;
	border-radius: 8px;
	box-sizing: border-box;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.des-hs-slide,
	.des-hs-eyebrow,
	.des-hs-title,
	.des-hs-button,
	.des-hs-arrow,
	.des-hs-dot {
		transition-duration: 1ms !important;
		animation-duration: 1ms !important;
		animation-delay: 0ms !important;
	}
}

/* Mobile defaults */
@media (max-width: 767px) {
	.des-hero-slider {
		--des-hs-content-padding: 32px 24px;
		--des-hs-arrow-size: 38px;
		--des-hs-arrow-offset: 12px;
	}

	.des-hs-dots {
		bottom: 14px;
	}
}
