/**
 * Motion Slider — frontend styles.
 */

.ms-slider {
	position: relative;
	width: 100%;
	height: var(--ms-h-desktop, 600px);
	overflow: hidden;
	background-color: var( --ms-bg-color, #0b0b0b );
	isolation: isolate;
	font-family: inherit;
}

.ms-slider * {
	box-sizing: border-box;
}

.ms-track {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

/* ---- Slides (stacked) ---- */
.ms-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	z-index: 1;
	pointer-events: none;
	background-color: var( --ms-bg-color, transparent );
	transition: opacity var( --ms-transition-duration, 0.8s ) ease, transform var( --ms-transition-duration, 0.8s ) ease;
}

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

/* Transition type is set per slide (class on each .ms-slide), so a single
   slider can mix transitions. The class describes how THIS slide enters. */

/* Slide: gentle horizontal motion in addition to fade. */
.ms-slide.ms-transition-slide {
	transform: translateX(6%);
}
.ms-slide.ms-transition-slide.is-active {
	transform: translateX(0);
}

/* Cross fade: overlapping easing, same configurable duration. */
.ms-slide.ms-transition-crossfade {
	transition: opacity var( --ms-transition-duration, 1.2s ) ease-in-out, visibility var( --ms-transition-duration, 1.2s ) ease-in-out;
}

/* Tiles (mosaic): the new slide appears instantly beneath an overlay of the
   previous image that disintegrates into squares. */
.ms-slide.ms-transition-tiles {
	transition: none;
}

.ms-tiles {
	position: absolute;
	inset: 0;
	z-index: 4;
	pointer-events: none;
	overflow: hidden;
}

.ms-tile {
	position: absolute;
	background-repeat: no-repeat;
	opacity: 1;
	transform: scale( 1 );
	transition-property: opacity, transform;
	transition-timing-function: cubic-bezier( 0.4, 0, 0.2, 1 );
	will-change: opacity, transform;
	backface-visibility: hidden;
}

.ms-tile.is-out {
	opacity: 0;
	transform: scale( 0.18 );
}

/* ---- Media ---- */
.ms-media-wrap {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.ms-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1);
	will-change: transform;
	backface-visibility: hidden;
}

.ms-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient( to top, rgba( 0, 0, 0, 1 ) 0%, rgba( 0, 0, 0, 0.27 ) 45%, rgba( 0, 0, 0, 0 ) 75% );
	opacity: var( --ms-overlay-opacity, 0.4 );
	z-index: 1;
}

/* Adaptive readability scrim: darken the side where the text sits. The peak
   alpha is 1; the actual strength is set via --ms-overlay-opacity (0 = off). */
.ms-vpos-bottom .ms-overlay {
	background: linear-gradient( to top, rgba( 0, 0, 0, 1 ) 0%, rgba( 0, 0, 0, 0.27 ) 45%, rgba( 0, 0, 0, 0 ) 75% );
}
.ms-vpos-top .ms-overlay {
	background: linear-gradient( to bottom, rgba( 0, 0, 0, 1 ) 0%, rgba( 0, 0, 0, 0.27 ) 45%, rgba( 0, 0, 0, 0 ) 75% );
}
.ms-vpos-middle .ms-overlay {
	background: radial-gradient( ellipse at center, rgba( 0, 0, 0, 1 ) 0%, rgba( 0, 0, 0, 0.55 ) 55%, rgba( 0, 0, 0, 0.22 ) 100% );
}

/* ---- Image effects (active slide only) ---- */
.ms-slide.is-active .ms-image.ms-effect-ken-burns { animation: ms-ken-burns 12s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-zoom-in   { animation: ms-zoom-in 10s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-zoom-out  { animation: ms-zoom-out 10s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-pan-left  { animation: ms-pan-left 12s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-pan-right { animation: ms-pan-right 12s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-pan-up    { animation: ms-pan-up 12s ease-out forwards; }
.ms-slide.is-active .ms-image.ms-effect-pan-down  { animation: ms-pan-down 12s ease-out forwards; }

@keyframes ms-ken-burns {
	from { transform: scale( 1 ) translate( 0, 0 ); }
	to   { transform: scale( 1.18 ) translate( -2%, -2% ); }
}
@keyframes ms-zoom-in  { from { transform: scale( 1 ); } to { transform: scale( 1.18 ); } }
@keyframes ms-zoom-out { from { transform: scale( 1.18 ); } to { transform: scale( 1 ); } }
@keyframes ms-pan-left  { from { transform: scale( 1.18 ) translateX( 4% ); } to { transform: scale( 1.18 ) translateX( -4% ); } }
@keyframes ms-pan-right { from { transform: scale( 1.18 ) translateX( -4% ); } to { transform: scale( 1.18 ) translateX( 4% ); } }
@keyframes ms-pan-up    { from { transform: scale( 1.18 ) translateY( 4% ); } to { transform: scale( 1.18 ) translateY( -4% ); } }
@keyframes ms-pan-down  { from { transform: scale( 1.18 ) translateY( -4% ); } to { transform: scale( 1.18 ) translateY( 4% ); } }

/* ---- Content ---- */
.ms-content {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	padding: clamp( 1.5rem, 5vw, 5rem );
	pointer-events: none;
}

/* Content position: vertical (set on the slide) */
.ms-vpos-top .ms-content    { align-items: flex-start; }
.ms-vpos-middle .ms-content { align-items: center; }
.ms-vpos-bottom .ms-content { align-items: flex-end; }

/* Content position: horizontal + matching text alignment */
.ms-hpos-left .ms-content   { justify-content: flex-start; }
.ms-hpos-center .ms-content { justify-content: center; }
.ms-hpos-right .ms-content  { justify-content: flex-end; }
.ms-hpos-left .ms-content-inner   { text-align: left; }
.ms-hpos-center .ms-content-inner { text-align: center; margin-left: auto; margin-right: auto; }
.ms-hpos-right .ms-content-inner  { text-align: right; }

.ms-content-inner {
	max-width: 640px;
	color: #fff;
	pointer-events: auto;
}

/* Text shadow direction (class set on the slide). Inherited by all text;
   the button resets it below so its label stays crisp on a solid background. */
.ms-shadow-none .ms-content-inner         { text-shadow: none; }
.ms-shadow-soft .ms-content-inner         { text-shadow: 0 0 14px rgba( 0, 0, 0, 0.65 ); }
.ms-shadow-top .ms-content-inner          { text-shadow: 0 -3px 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-bottom .ms-content-inner       { text-shadow: 0 3px 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-left .ms-content-inner         { text-shadow: -3px 0 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-right .ms-content-inner        { text-shadow: 3px 0 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-top-left .ms-content-inner     { text-shadow: -3px -3px 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-top-right .ms-content-inner    { text-shadow: 3px -3px 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-bottom-left .ms-content-inner  { text-shadow: -3px 3px 8px rgba( 0, 0, 0, 0.7 ); }
.ms-shadow-bottom-right .ms-content-inner { text-shadow: 3px 3px 8px rgba( 0, 0, 0, 0.7 ); }

.ms-subtitle {
	margin: 0 0 0.5rem;
	font-size: clamp( 0.8rem, 1.4vw, 1rem );
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-weight: 600;
	opacity: 0.92;
}

.ms-title {
	margin: 0 0 0.75rem;
	font-size: clamp( 1.8rem, 5vw, 3.6rem );
	line-height: 1.08;
	font-weight: 700;
}

.ms-desc {
	margin: 0 0 1.25rem;
	font-size: clamp( 0.95rem, 1.6vw, 1.15rem );
	line-height: 1.55;
	opacity: 0.95;
}
.ms-desc p { margin: 0 0 0.5rem; }

.ms-button {
	display: inline-block;
	padding: 0.85em 1.9em;
	font-weight: 600;
	text-decoration: none;
	text-shadow: none;
	border-radius: 2px;
	letter-spacing: 0.02em;
	transition: transform 0.25s ease, background 0.25s ease, color 0.25s ease;
}
.ms-button:hover,
.ms-button:focus-visible {
	transform: translateY( -2px );
}

/* Theme-proof text colors. Scoped under .ms-slider and flagged !important so
   no theme heading/link/paragraph rule can override them. Values flow through
   CSS variables set per slider / per slide; the fallback is the built-in color. */
.ms-slider .ms-subtitle { color: var( --ms-subtitle-color, #fff ) !important; }
.ms-slider .ms-title    { color: var( --ms-title-color, #fff ) !important; }
.ms-slider .ms-desc,
.ms-slider .ms-desc p   { color: var( --ms-desc-color, #fff ) !important; }
.ms-slider .ms-button {
	background-color: var( --ms-btn-bg-color, #fff ) !important;
	color: var( --ms-btn-text-color, #111 ) !important;
}
.ms-slider .ms-button:hover,
.ms-slider .ms-button:focus-visible {
	background-color: var( --ms-btn-text-color, #111 ) !important;
	color: var( --ms-btn-bg-color, #fff ) !important;
}

/* ---- Content animations (active slide only) ---- */
.ms-slide.is-active .ms-content.ms-anim-fade-up     { animation: ms-fade-up 0.9s 0.25s ease both; }
.ms-slide.is-active .ms-content.ms-anim-fade-down   { animation: ms-fade-down 0.9s 0.25s ease both; }
.ms-slide.is-active .ms-content.ms-anim-slide-left  { animation: ms-slide-left 0.9s 0.25s ease both; }
.ms-slide.is-active .ms-content.ms-anim-slide-right { animation: ms-slide-right 0.9s 0.25s ease both; }
.ms-slide.is-active .ms-content.ms-anim-zoom        { animation: ms-content-zoom 0.9s 0.25s ease both; }

@keyframes ms-fade-up     { from { opacity: 0; transform: translateY( 40px ); } to { opacity: 1; transform: none; } }
@keyframes ms-fade-down   { from { opacity: 0; transform: translateY( -40px ); } to { opacity: 1; transform: none; } }
@keyframes ms-slide-left  { from { opacity: 0; transform: translateX( 60px ); } to { opacity: 1; transform: none; } }
@keyframes ms-slide-right { from { opacity: 0; transform: translateX( -60px ); } to { opacity: 1; transform: none; } }
@keyframes ms-content-zoom { from { opacity: 0; transform: scale( 0.9 ); } to { opacity: 1; transform: none; } }

/* ---- Arrows ---- */
.ms-arrow {
	position: absolute;
	top: 50%;
	transform: translateY( -50% );
	z-index: 5;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0;
	border-radius: 50%;
	background: rgba( 0, 0, 0, 0.35 );
	color: #fff;
	cursor: pointer;
	transition: background 0.25s ease, transform 0.25s ease;
	backdrop-filter: blur( 4px );
}
.ms-arrow:hover { background: rgba( 0, 0, 0, 0.6 ); }
.ms-arrow svg { width: 24px; height: 24px; }
.ms-arrow-prev { left: 16px; }
.ms-arrow-next { right: 16px; }
.ms-arrow:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }

/* ---- Play / pause ---- */
.ms-playpause {
	position: absolute;
	right: 16px;
	bottom: 16px;
	z-index: 5;
	width: 40px;
	height: 40px;
	border: 0;
	border-radius: 50%;
	background: rgba( 0, 0, 0, 0.35 );
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur( 4px );
}
.ms-playpause:hover { background: rgba( 0, 0, 0, 0.6 ); }
.ms-playpause:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }
.ms-icon-pause,
.ms-icon-play { display: block; }
.ms-icon-pause {
	width: 12px; height: 14px;
	border-left: 4px solid #fff;
	border-right: 4px solid #fff;
}
.ms-icon-play {
	width: 0; height: 0;
	border-left: 12px solid #fff;
	border-top: 8px solid transparent;
	border-bottom: 8px solid transparent;
	display: none;
}
.ms-playpause[data-state="paused"] .ms-icon-pause { display: none; }
.ms-playpause[data-state="paused"] .ms-icon-play { display: block; }

/* ---- Dots ---- */
.ms-dots {
	position: absolute;
	left: 50%;
	bottom: 18px;
	transform: translateX( -50% );
	z-index: 5;
	display: flex;
	gap: 10px;
}
.ms-dot {
	width: 11px;
	height: 11px;
	padding: 0;
	border: 2px solid rgba( 255, 255, 255, 0.85 );
	border-radius: 50%;
	background: transparent;
	cursor: pointer;
	transition: background 0.25s ease, transform 0.25s ease;
}
.ms-dot.is-active { background: #fff; transform: scale( 1.2 ); }
.ms-dot:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }

/* ---- Responsive heights ---- */
@media ( max-width: 1024px ) {
	.ms-slider { height: var( --ms-h-tablet, 500px ); }
}
@media ( max-width: 600px ) {
	.ms-slider { height: var( --ms-h-mobile, 400px ); }
	.ms-arrow { width: 40px; height: 40px; }
	.ms-arrow svg { width: 20px; height: 20px; }
	.ms-content { padding: 1.25rem; }
}

/* ---- Reduced motion ---- */
@media ( prefers-reduced-motion: reduce ) {
	.ms-slide,
	.ms-image,
	.ms-content,
	.ms-tile,
	.ms-button { transition: none !important; animation: none !important; }
	.ms-image { transform: none !important; }
	.ms-tile { transform: none !important; opacity: 0 !important; }
	.ms-content { opacity: 1 !important; }
}
