/* ============================================================
   Lightweight Google Review — Frontend Styles v1.1.0
   ============================================================ */

/* ---- Wrapper ---- */
.lgr-reviews-wrapper {
	width: 100%;
	box-sizing: border-box;
}

/* ---- Review Card ---- */
.lgr-review-card {
	background: #fff;
	border-radius: 10px;
	padding: 20px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* Card Variants */
.lgr-card-flat {
	background: #f9f9f9;
	box-shadow: none;
}

.lgr-card-shadow {
	box-shadow: 0 2px 14px rgba(0, 0, 0, .09);
}

.lgr-card-bordered {
	border: 1px solid #e0e0e0;
	box-shadow: none;
}

/* ---- Card Header (foto + info) ---- */
.lgr-card-header {
	display: flex;
	align-items: center;
	gap: 12px;
}

.lgr-reviewer-photo {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	border: 2px solid #f0f0f0;
}

.lgr-reviewer-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.lgr-reviewer-name {
	font-weight: 700;
	font-size: 0.95em;
	color: #1d2327;
	line-height: 1.3;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.lgr-review-date {
	font-size: 0.82em;
	color: #9ea4a9;
	line-height: 1.2;
}

/* ---- Stars ---- */
.lgr-stars {
	display: inline-flex;
	align-items: center;
	gap: 1px;
	line-height: 1;
}

.lgr-stars svg {
	display: block;
}

/* ---- Review Text ---- */
.lgr-review-text {
	font-size: 0.93em;
	line-height: 1.65;
	color: #3c434a;
	flex: 1;
}

.lgr-review-text .lgr-text-full {
	display: none;
}

.lgr-review-text.lgr-expanded .lgr-text-excerpt {
	display: none;
}

.lgr-review-text.lgr-expanded .lgr-text-full {
	display: inline;
}

.lgr-read-more,
.lgr-read-less {
	color: #2271b1;
	cursor: pointer;
	font-size: 0.9em;
	font-weight: 600;
	text-decoration: underline;
	margin-left: 4px;
	user-select: none;
}

.lgr-read-more:hover,
.lgr-read-less:hover {
	color: #135e96;
}

/* ---- Reviewer Link (foto + nama → profil Google) ---- */
.lgr-reviewer-link {
	text-decoration: none;
	color: inherit;
	display: contents;
}

.lgr-reviewer-link:hover .lgr-reviewer-name {
	text-decoration: underline;
	color: #2271b1;
}

.lgr-reviewer-link:hover .lgr-reviewer-photo {
	opacity: .85;
}

/* ---- Verify Link ---- */
.lgr-verify-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.8em;
	color: #5f6368;
	text-decoration: none;
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	padding: 4px 10px;
	width: fit-content;
	transition: border-color .15s, color .15s;
	margin-top: auto;
}

.lgr-verify-link:hover {
	color: #1a73e8;
	border-color: #1a73e8;
	text-decoration: none;
}

.lgr-verify-link::before {
	content: '';
	display: inline-block;
	width: 12px;
	height: 12px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%234285F4'%3E%3Cpath d='M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z'/%3E%3Cpath d='M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z'/%3E%3Cpath d='M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l3.66-2.84z'/%3E%3Cpath d='M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
}

/* ---- Layouts ---- */

/* Grid */
.lgr-layout-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 20px;
}

/* List */
.lgr-layout-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.lgr-layout-list .lgr-review-card {
	flex-direction: row;
	align-items: flex-start;
}

.lgr-layout-list .lgr-card-left {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex-shrink: 0;
	width: 64px;
	text-align: center;
	gap: 6px;
}

.lgr-layout-list .lgr-card-left .lgr-reviewer-name {
	font-size: 0.78em;
	word-break: break-word;
	white-space: normal;
}

.lgr-layout-list .lgr-card-body {
	flex: 1;
	min-width: 0;
}

/* ---- Slider (native CSS scroll-snap) ---- */
.lgr-layout-slider {
	/* CSS custom properties di-set via inline style dari PHP settings */
	--lgr-slides: var(--lgr-slides-mobile, 1);
}

.lgr-slider-track {
	display: flex;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	gap: 16px;
	scrollbar-width: none;
	padding-bottom: 4px;
	/* Izinkan swipe vertikal, block konflik horizontal */
	touch-action: pan-y pinch-zoom;
}

.lgr-slider-track::-webkit-scrollbar {
	display: none;
}

.lgr-slider-track .lgr-review-card {
	scroll-snap-align: start;
	/* Lebar per slide = (100% - gap × (slides-1)) / slides */
	flex: 0 0 calc((100% - 16px * (var(--lgr-slides) - 1)) / var(--lgr-slides));
	min-width: 240px;
	height: auto;
}

/* ---- Slider Navigation ---- */
.lgr-slider-nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin-top: 14px;
}

.lgr-slider-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid #e0e0e0;
	background: #fff;
	cursor: pointer;
	color: #2271b1;
	box-shadow: 0 1px 4px rgba(0, 0, 0, .10);
	transition: background .15s, border-color .15s;
	padding: 0;
	flex-shrink: 0;
}

.lgr-slider-btn:hover:not(:disabled) {
	background: #f0f6fc;
	border-color: #2271b1;
}

.lgr-slider-btn:disabled {
	opacity: .4;
	cursor: default;
}

.lgr-slider-btn svg {
	display: block;
	width: 16px;
	height: 16px;
}

/* ---- Slider Dots ---- */
.lgr-slider-dots {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-top: 10px;
}

.lgr-slider-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #d0d5dd;
	border: none;
	padding: 0;
	cursor: pointer;
	transition: background .15s, transform .15s;
}

.lgr-slider-dot.lgr-dot-active,
.lgr-slider-dot:hover {
	background: #2271b1;
	transform: scale(1.2);
}

/* ---- Responsive ---- */

/* Slider: responsive slides via CSS variables */
@media (min-width: 769px) {
	.lgr-layout-slider {
		--lgr-slides: var(--lgr-slides-tablet, 2);
	}
}

@media (min-width: 1025px) {
	.lgr-layout-slider {
		--lgr-slides: var(--lgr-slides-desktop, 3);
	}
}

@media (max-width: 768px) {
	.lgr-review-card {
		padding: 16px;
	}

	.lgr-layout-grid {
		grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
		gap: 14px;
	}

	.lgr-layout-list .lgr-review-card {
		flex-direction: column;
	}

	.lgr-layout-list .lgr-card-left {
		flex-direction: row;
		width: auto;
	}
}

@media (max-width: 480px) {
	.lgr-review-card {
		padding: 14px;
		gap: 10px;
	}

	.lgr-layout-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.lgr-layout-list .lgr-review-card {
		flex-direction: column;
		gap: 10px;
	}

	.lgr-layout-list .lgr-card-left {
		flex-direction: row;
		width: 100%;
		align-items: center;
	}

	.lgr-reviewer-photo {
		width: 36px;
		height: 36px;
	}

	.lgr-verify-link {
		padding: 6px 12px;
		font-size: 0.85em;
	}

	.lgr-slider-track .lgr-review-card {
		min-width: 200px;
	}
}

@media (max-width: 360px) {
	.lgr-review-card {
		padding: 12px;
		gap: 8px;
	}

	.lgr-reviewer-photo {
		width: 32px;
		height: 32px;
	}

	.lgr-review-date {
		font-size: 0.8em;
	}
}
