/* ku-why-us.css */

.ku-why-us {
	position: relative;
	overflow: hidden;
	width: 100%;
}

.ku-why-us__container {
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

@media (min-width: 768px) {
	.ku-why-us__container {
		padding-left: 2rem;
		padding-right: 2rem;
	}
}

@media (min-width: 1024px) {
	.ku-why-us__container {
		padding-left: 2.5rem;
		padding-right: 2.5rem;
	}
}

.ku-why-us__row {
	display: flex;
	flex-direction: var(--row-direction, column);
	gap: var(--row-gap, 3rem);
}

@media (min-width: 1024px) {
	.ku-why-us__row {
		flex-direction: var(--row-direction, row);
		align-items: center;
		gap: var(--row-gap, 4rem);
	}
}

.ku-why-us__col {
	width: 100%;
}

.ku-why-us__col--features {
	order: 2;
}

.ku-why-us__col--image {
	order: 1;
	position: relative;
}

@media (min-width: 1024px) {
	.ku-why-us__col--features {
		width: 50%;
		order: 1;
	}

	.ku-why-us__col--image {
		width: 50%;
		order: 2;
	}
}

.ku-why-us__badge {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	margin-bottom: 0.5rem;
}

.ku-why-us__title {
	font-size: 1.875rem;
	font-weight: 700;
	line-height: 1.25;
	margin-top: 0;
	margin-bottom: 2rem;
}

@media (min-width: 768px) {
	.ku-why-us__title {
		font-size: 2.25rem;
	}
}

.ku-why-us__features {
	display: grid;
}

.ku-why-us__feature {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
}

.ku-why-us__feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Hover micro-animation on feature rows */
.ku-why-us__feature:hover .ku-why-us__feature-icon {
	transform: scale(1.08) rotate(4deg);
	box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.05), 0 8px 10px -6px rgba(0, 0, 0, 0.05);
}

.ku-why-us__feature-icon i {
	line-height: 1;
}

.ku-why-us__feature-icon svg {
	fill: currentColor;
}

.ku-why-us__feature-content {
	flex: 1;
}

.ku-why-us__feature-title {
	font-size: 1.125rem;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 0.25rem;
	transition: color 0.3s ease;
}

.ku-why-us__feature-desc {
	font-size: 0.875rem;
	font-weight: 300;
	line-height: 1.625;
	margin: 0;
}

.ku-why-us__image-container {
	position: relative;
	width: 100%;
	height: 440px;
	overflow: visible;
	/* background: linear-gradient(135deg, #FDE3F1 0%, #F3E5F7 100%); */
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.ku-why-us__image-container:hover {
	transform: translateY(-4px);
}

.ku-why-us__image {
	width: 100%;
	height: 100%;
	object-fit: var(--image-object-fit, cover);
	object-position: var(--image-object-x, 50%) var(--image-object-y, 50%);
	transform: translate3d(var(--image-x, 0px), var(--image-y, 0px), 0) scale(var(--image-scale, 1));
	transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.ku-why-us__image-container:hover .ku-why-us__image {
	transform: translate3d(var(--image-x, 0px), var(--image-y, 0px), 0) scale(calc(var(--image-scale, 1) * 1.03));
}

.ku-why-us__image-placeholder {
	text-align: center;
	padding: 3rem;
	opacity: 0.3;
}

.ku-why-us__placeholder-icon {
	font-size: 6rem;
	margin-bottom: 1rem;
}

.ku-why-us__placeholder-text {
	font-size: 1.125rem;
	font-weight: 300;
	margin: 0;
}

/* Decorative background circles */
.ku-why-us__deco-circle {
	position: absolute;
	border-radius: 50%;
	z-index: -1;
	pointer-events: none;
	opacity: 0.15;
	transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.ku-why-us__deco-circle--1 {
	top: -1.25rem;
	left: -1.25rem;
	width: 5rem;
	height: 5rem;
	background: radial-gradient(circle, var(--secondary, #3F51B5) 0%, rgba(63, 81, 181, 0) 70%);
}

.ku-why-us__deco-circle--2 {
	bottom: -1.25rem;
	right: -1.25rem;
	width: 7rem;
	height: 7rem;
	background: radial-gradient(circle, var(--primary, #EC008C) 0%, rgba(236, 0, 140, 0) 70%);
}

.ku-why-us__col--image:hover .ku-why-us__deco-circle--1 {
	transform: scale(1.2) translate(-8px, -8px);
}

.ku-why-us__col--image:hover .ku-why-us__deco-circle--2 {
	transform: scale(1.2) translate(10px, 10px);
}

/* Image Position Layout Shifts */
@media (min-width: 1024px) {
	.ku-why-us__row--image-left .ku-why-us__col--features {
		order: 2;
	}

	.ku-why-us__row--image-left .ku-why-us__col--image {
		order: 1;
	}
}