/**
 * Reviews Slider — [cataleya_reviews_slider]
 * Prefix: ct-rv-slider
 * CSS scroll snap, zero dependencies
 */

.ct-rv-slider {
	position: relative;
}

/* ── Track (scroll snap container) ───────── */

.ct-rv-slider__track {
	display: flex;
	gap: 16px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding: 4px 2px 8px;
}

.ct-rv-slider__track::-webkit-scrollbar {
	display: none;
}

/* ── Slide ────────────────────────────────── */

.ct-rv-slider__slide {
	flex: 0 0 calc(33.333% - 11px);
	scroll-snap-align: start;
	min-width: 240px;
	display: flex;
}

.ct-rv-slider__card {
	background: #f7f7f7;
	border: 1px solid #f0f0f0;
	border-radius: 12px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	width: 100%;
}

/* ── Header: avatar + name ───────────────── */

.ct-rv-slider__header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.ct-rv-slider__avatar-wrap {
	position: relative;
	flex-shrink: 0;
}

.ct-rv-slider__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: #ffecef;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 500;
	font-size: 0.9375rem;
	color: #c61932;
}

.ct-rv-slider__verified {
	position: absolute;
	bottom: 0;
	right: -2px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: #2e7d32;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #fff;
}

.ct-rv-slider__verified svg {
	width: 8px;
	height: 8px;
}

.ct-rv-slider__author {
	display: flex;
	flex-direction: column;
}

.ct-rv-slider__name {
	font-size: 1.0625rem;
	font-weight: 600;
}

.ct-rv-slider__verified-text {
	font-size: 0.75rem;
	color: #2e7d32;
}

/* ── Rating ───────────────────────────────── */

.ct-rv-slider__rating {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 10px;
}

.ct-rv-slider__stars {
	display: inline-flex;
	gap: 1px;
}

.ct-rv-slider__rating-text {
	font-size: 0.8125rem;
}

/* ── Text ─────────────────────────────────── */

.ct-rv-slider__text {
	font-size: 0.9375rem;
	line-height: 1.55;
	margin: 0 0 auto;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ── Photos ───────────────────────────────── */

.ct-rv-slider__photos {
	display: flex;
	gap: 6px;
	margin-top: 10px;
}

.ct-rv-slider__photo {
	width: 56px;
	height: 56px;
	border-radius: 6px;
	object-fit: cover;
}

/* ── Date ─────────────────────────────────── */

.ct-rv-slider__date {
	font-size: 0.75rem;
	margin-top: 10px;
}

/* ── Product link ─────────────────────────── */

.ct-rv-slider__product {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	margin-top: 12px;
	background: #fff;
	border-radius: 8px;
	text-decoration: none;
	transition: background 0.15s;
}

.ct-rv-slider__product:hover {
	background: #ffecef;
}

.ct-rv-slider__product-img {
	width: 44px;
	height: 44px;
	border-radius: 6px;
	object-fit: cover;
	flex-shrink: 0;
}

.ct-rv-slider__product-name {
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ── Navigation arrows ────────────────────── */

.ct-rv-slider__nav {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #fff;
	border: 1px solid #e5e5e5;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0,0,0,0.08);
	transition: border-color 0.15s, box-shadow 0.15s;
}

.ct-rv-slider__nav:hover {
	border-color: #c41230;
	box-shadow: 0 2px 12px rgba(0,0,0,0.12);
}

.ct-rv-slider__nav--prev { margin-right: 8px; }
.ct-rv-slider__nav--next { margin-left: 8px; }

.ct-rv-slider__nav-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 1.25rem;
}

/* ── Responsive ───────────────────────────── */

@media (max-width: 1024px) {
	.ct-rv-slider__slide {
		flex: 0 0 calc(50% - 8px);
		min-width: 260px;
	}
}

@media (max-width: 600px) {
	.ct-rv-slider__slide {
		flex: 0 0 85%;
		min-width: 240px;
	}

	.ct-rv-slider__nav-wrap { display: none; }

	.ct-rv-slider__card { padding: 16px; }
}