/* ==========================================================================
   Vivaia Feature Highlight Widget
   ========================================================================== */

/* Container */
.vivaia-fhl-container {
	display: flex;
	font-family: Roboto, sans-serif;
	background-color: var(--fhl-bg, #FCFBF7);
	box-sizing: border-box;
}

.vivaia-fhl-container *,
.vivaia-fhl-container *::before,
.vivaia-fhl-container *::after {
	box-sizing: border-box;
}

/* --------------------------------------------------------------------------
   Text Area (Left side on Desktop)
   -------------------------------------------------------------------------- */
.vivaia-fhl-text-area {
	width: 38%;
	display: flex;
	align-items: center;
	padding: 40px;
}

.vivaia-fhl-item-box {
	width: 100%;
}

/* Individual Item */
.vivaia-fhl-item {
	display: flex;
	gap: 16px;
	padding: 20px 0;
	cursor: pointer;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	align-items: flex-start;
	outline: none;
}

.vivaia-fhl-item:last-child {
	border-bottom: none;
}

/* Number Circle */
.vivaia-fhl-num-box {
	width: 32px;
	height: 32px;
	min-width: 32px;
	border-radius: 50%;
	border: 1.5px solid var(--fhl-num-color, #9E9E9E);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--fhl-num-size, 14px);
	color: var(--fhl-num-color, #9E9E9E);
	font-weight: 400;
	line-height: 1;
	transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.vivaia-fhl-num-box.active {
	background-color: var(--fhl-num-active-bg, #C4C4C4);
	color: var(--fhl-num-active-color, #FFFFFF);
	border-color: var(--fhl-num-active-bg, #C4C4C4);
}

.vivaia-fhl-item:hover .vivaia-fhl-num-box {
	background-color: #000000;
	color: #FFFFFF;
	border-color: #000000;
}

/* Item Content */
.vivaia-fhl-item-content {
	flex: 1;
	padding-top: 4px;
}

.vivaia-fhl-title {
	font-size: var(--fhl-title-size, 22px);
	font-weight: 500;
	color: var(--fhl-title-color, #261B02);
	line-height: 1.3;
	margin: 0;
}

.vivaia-fhl-desc {
	font-size: var(--fhl-desc-size, 14px);
	color: var(--fhl-desc-color, #666666);
	line-height: 1.5;
	margin-top: 6px;
}

/* --------------------------------------------------------------------------
   Image Area (Right side on Desktop)
   -------------------------------------------------------------------------- */
.vivaia-fhl-img-area {
	width: 62%;
	position: relative;
	overflow: hidden;
	aspect-ratio: var(--fhl-desk-ratio, 1112/736);
}

.vivaia-fhl-point-img {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 0.4s ease;
	display: block;
}

.vivaia-fhl-point-img.active {
	opacity: 1;
}

.vivaia-fhl-point-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* --------------------------------------------------------------------------
   Focus Styles
   -------------------------------------------------------------------------- */
.vivaia-fhl-item:focus-visible {
	outline: 2px solid var(--fhl-num-active-bg, #C4C4C4);
	outline-offset: 2px;
	border-radius: 4px;
}

/* --------------------------------------------------------------------------
   Reduced Motion
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.vivaia-fhl-num-box,
	.vivaia-fhl-point-img {
		transition: none;
	}
}

/* --------------------------------------------------------------------------
   Elementor Editor
   -------------------------------------------------------------------------- */
.elementor-editor-active .vivaia-fhl-point-img {
	opacity: 0.3;
}

.elementor-editor-active .vivaia-fhl-point-img.active {
	opacity: 1;
}

/* --------------------------------------------------------------------------
   Mobile (max-width: 768px)
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
	.vivaia-fhl-container {
		flex-direction: column-reverse;
		padding: 10px 10px 39px;
	}

	.vivaia-fhl-text-area {
		width: 100%;
		padding: 20px 10px;
	}

	.vivaia-fhl-item-box {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 16px;
	}

	.vivaia-fhl-item {
		padding: 12px 0;
		border-bottom: none;
		gap: 10px;
	}

	.vivaia-fhl-num-box {
		width: 26px;
		height: 26px;
		min-width: 26px;
		font-size: 12px;
	}

	.vivaia-fhl-title {
		font-size: 14px;
	}

	.vivaia-fhl-img-area {
		width: 100%;
		display: grid;
	}

	.vivaia-fhl-point-img {
		grid-area: 1 / 1;
		position: relative;
		inset: auto;
	}

	.vivaia-fhl-point-img img {
		height: auto;
	}
}
