/* ===== RIB – Wrapper (mobile slider only) ===== */
.rib-slider-wrapper {
	position: relative;
	width: 100%;
	overflow: hidden !important;
	padding-bottom: 30px; /* Space for dots */
}

/* ===== Desktop: standard flex row ===== */
.rib-benefits {
	--rib-accent: #d10000;

	display: flex !important;
	gap: 0 !important;
	justify-content: space-between !important;
	align-items: flex-start !important;
	flex-wrap: nowrap !important;
	padding: 24px 0;
	width: 100%;
}

.rib-track {
	display: inherit;
	gap: inherit;
	justify-content: inherit;
	align-items: inherit;
	flex-wrap: inherit;
	width: 100%;
	transition: transform 0.4s ease;
	will-change: transform;
	gap: 20px !important;
}

.rib-benefit {
	flex: 1 1 0 !important;
	min-width: 0 !important;
	max-width: none !important;
	text-align: center;
}

.rib-benefit__icon {
	margin: auto;
	display: flex;
	width: fit-content;
	color: var(--rib-accent);
	margin-bottom: 20px;
	transition: transform 160ms ease, color 160ms ease;
}

.rib-benefit__icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.rib-benefit__title {
	font-weight: 600;
	color: #111;
	line-height: 1.25;
	transition: color 160ms ease;
}

.rib-benefit__desc {
	margin-top: 6px;
	color: #333;
	line-height: 1.35;
}

.rib-benefit:hover .rib-benefit__icon {
	transform: scale(1.06);
}

.rib-benefit:hover .rib-benefit__title {
	color: #000;
}

/* ===== Dots navigation (shared look with product slider) ===== */
.rib-dots {
	margin-top: 20px;
	display: flex;
	gap: 8px;
	justify-content: center;
}

.rib-dot {
	display: block !important;
	width: 60px !important;
	height: 4px !important;
	min-height: 4px !important;
	border-radius: 999px !important;
	background-color: #fbece6 !important; 
	cursor: pointer !important;
	border: none !important;
	padding: 0 !important;
	transition: all 0.3s ease !important;
	flex: 0 0 auto !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.rib-dot:hover {
	background: rgba(30, 30, 30, 0.3);
}

.rib-dot[aria-current="true"] {
	background: var(--Foundation-Grey-G900, #1E1E1E);
}

/* ===== Mobile/Tablet (≤ 991px): switch to slider ===== */
@media (max-width: 991px) {
	.rib-benefits {
		overflow: hidden !important;
		justify-content: flex-start !important;
		padding: 24px 0 !important;
		padding-right: 20px !important; /* Minimal buffer */
		gap: 20px !important;
	}

	.rib-track {
		justify-content: flex-start !important;
		flex-wrap: nowrap !important;
		cursor: grab;
		user-select: none;
		-webkit-user-select: none;
	}

	.rib-track.rib-dragging {
		transition: none !important;
		cursor: grabbing;
	}

	.rib-benefit {
		flex: 0 0 280px !important; 
		min-width: 280px !important;
		width: 280px !important;
		margin: 0 !important; 
	}
}
