/**
 * Google Places Reviews - Frontend Styles
 *
 * @package GooglePlacesReviews
 */

/* ==========================================================================
   Base Styles
   ========================================================================== */

.gpr-reviews {
	margin: 1.5em 0;
	font-size: 16px;
	line-height: 1.6;
}

.gpr-reviews *,
.gpr-reviews *::before,
.gpr-reviews *::after {
	box-sizing: border-box;
}

/* ==========================================================================
   Single Review
   ========================================================================== */

.gpr-review {
	margin-bottom: 1.5em;
	padding: 1.25em;
	background: #fff;
	border: 1px solid #e0e0e0;
	border-radius: 8px;
}

.gpr-review:last-child {
	margin-bottom: 0;
}

/* Review Header */
.gpr-review__header {
	display: flex;
	align-items: flex-start;
	gap: 1em;
	margin-bottom: 1em;
}

/* Avatar */
.gpr-review__avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	flex-shrink: 0;
	object-fit: cover;
}

.gpr-review__avatar--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #4285f4;
	color: #fff;
	font-size: 1.25em;
	font-weight: 600;
	text-transform: uppercase;
}

/* Meta Info */
.gpr-review__meta {
	flex: 1;
	min-width: 0;
}

.gpr-review__author {
	display: block;
	font-weight: 600;
	font-size: 1em;
	color: #333;
	text-decoration: none;
	margin-bottom: 0.25em;
}

a.gpr-review__author:hover {
	color: #4285f4;
	text-decoration: underline;
}

/* Rating */
.gpr-review__rating {
	display: flex;
	align-items: center;
	gap: 0.5em;
	margin-bottom: 0.25em;
}

.gpr-review__stars {
	display: inline-flex;
	color: #fbbc04;
	font-size: 1em;
	letter-spacing: 1px;
}

.gpr-review__star--empty {
	color: #dadce0;
}

.gpr-review__rating-text {
	font-size: 0.875em;
	color: #5f6368;
}

/* Date */
.gpr-review__date {
	display: block;
	font-size: 0.875em;
	color: #70757a;
}

/* Content */
.gpr-review__content {
	padding-top: 0.5em;
}

.gpr-review__text {
	margin: 0;
	color: #3c4043;
	line-height: 1.6;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

/* ==========================================================================
   List Layout
   ========================================================================== */

.gpr-reviews--list .gpr-review {
	max-width: 100%;
}

/* ==========================================================================
   Grid Layout
   ========================================================================== */

.gpr-reviews--grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 1.5em;
}

.gpr-reviews--grid .gpr-review {
	margin-bottom: 0;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.gpr-reviews--grid .gpr-review__content {
	flex: 1;
}

/* ==========================================================================
   Cards Layout
   ========================================================================== */

.gpr-reviews--cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 1.5em;
}

.gpr-reviews--cards .gpr-review {
	margin-bottom: 0;
	padding: 1.5em;
	background: #fff;
	border: none;
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08), 0 4px 16px rgba(0, 0, 0, 0.06);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.gpr-reviews--cards .gpr-review:hover {
	transform: translateY(-4px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 8px 24px rgba(0, 0, 0, 0.08);
}

.gpr-reviews--cards .gpr-review__header {
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.75em;
}

.gpr-reviews--cards .gpr-review__avatar {
	width: 64px;
	height: 64px;
}

.gpr-reviews--cards .gpr-review__meta {
	text-align: center;
}

.gpr-reviews--cards .gpr-review__rating {
	justify-content: center;
}

.gpr-reviews--cards .gpr-review__content {
	flex: 1;
	text-align: center;
}

.gpr-reviews--cards .gpr-review__text {
	font-size: 0.95em;
}

/* ==========================================================================
   View More Link
   ========================================================================== */

.gpr-view-more {
	margin-top: 1.5em;
	text-align: center;
}

.gpr-view-more__link {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.75em 1.5em;
	background: linear-gradient(135deg, #4285f4 0%, #34a853 100%);
	color: #fff;
	text-decoration: none;
	border-radius: 50px;
	font-weight: 500;
	font-size: 0.95em;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	box-shadow: 0 2px 8px rgba(66, 133, 244, 0.3);
}

.gpr-view-more__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(66, 133, 244, 0.4);
	color: #fff;
}

.gpr-view-more__link:active {
	transform: translateY(0);
}

.gpr-view-more__icon {
	display: inline-flex;
	align-items: center;
}

.gpr-view-more__icon svg {
	width: 16px;
	height: 16px;
}

/* Alternative styles for different layouts */
.gpr-reviews--cards + .gpr-view-more {
	margin-top: 2em;
}

.gpr-reviews--list + .gpr-view-more {
	text-align: left;
}

.gpr-reviews--list + .gpr-view-more .gpr-view-more__link {
	background: transparent;
	color: #4285f4;
	padding: 0.5em 0;
	box-shadow: none;
	border-radius: 0;
}

.gpr-reviews--list + .gpr-view-more .gpr-view-more__link:hover {
	color: #1a73e8;
	box-shadow: none;
	transform: none;
	text-decoration: underline;
}

/* ==========================================================================
	  Leave Review Button
	  ========================================================================== */

.gpr-leave-review {
	margin-top: 1.5em;
	text-align: center;
}

.gpr-leave-review__button,
.gpr-leave-review__link {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.875em 2em;
	background: linear-gradient(135deg, #fbbc04 0%, #ea4335 100%);
	color: #fff;
	text-decoration: none;
	border-radius: 50px;
	font-weight: 600;
	font-size: 1em;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 3px 10px rgba(251, 188, 4, 0.4);
	border: none;
	cursor: pointer;
}

.gpr-leave-review__button:hover,
.gpr-leave-review__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 5px 15px rgba(251, 188, 4, 0.5);
	color: #fff;
}

.gpr-leave-review__button:active,
.gpr-leave-review__link:active {
	transform: translateY(0);
}

.gpr-leave-review__icon {
	font-size: 1.2em;
	line-height: 1;
}

.gpr-leave-review__text {
	font-weight: 600;
}

/* Link style variant */
.gpr-leave-review__link {
	background: transparent;
	color: #fbbc04;
	padding: 0.5em 0;
	box-shadow: none;
	border-radius: 0;
	font-weight: 500;
}

.gpr-leave-review__link:hover {
	color: #ea4335;
	box-shadow: none;
	transform: none;
	text-decoration: underline;
}

/* Layout-specific styles */
.gpr-reviews--list + .gpr-view-more + .gpr-leave-review,
.gpr-reviews--list + .gpr-leave-review {
	text-align: left;
}

.gpr-reviews--cards + .gpr-view-more + .gpr-leave-review,
.gpr-reviews--cards + .gpr-leave-review {
	margin-top: 2em;
}

/* ==========================================================================
	  Error & Empty States
	  ========================================================================== */

.gpr-error,
.gpr-no-reviews {
	padding: 1.5em;
	background: #fafafa;
	border: 1px solid #e0e0e0;
	border-radius: 8px;
	color: #5f6368;
	text-align: center;
}

.gpr-error--admin {
	background: #fef7e0;
	border-color: #f9ab00;
	text-align: left;
}

.gpr-error--admin p {
	margin: 0.5em 0;
}

.gpr-error--admin a {
	color: #1a73e8;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media screen and (max-width: 768px) {
	.gpr-reviews {
		font-size: 15px;
	}

	.gpr-reviews--grid,
	.gpr-reviews--cards {
		grid-template-columns: 1fr;
	}

	.gpr-review {
		padding: 1em;
	}

	.gpr-review__avatar {
		width: 40px;
		height: 40px;
	}

	.gpr-reviews--cards .gpr-review__avatar {
		width: 56px;
		height: 56px;
	}

	.gpr-review__header {
		gap: 0.75em;
	}
}

@media screen and (max-width: 480px) {
	.gpr-review__header {
		flex-direction: column;
		align-items: flex-start;
	}

	.gpr-reviews--list .gpr-review__header {
		flex-direction: row;
	}

	.gpr-review__rating {
		flex-wrap: wrap;
	}
}

/* ==========================================================================
   Dark Mode Support (if theme supports it)
   ========================================================================== */

@media (prefers-color-scheme: dark) {
	.gpr-reviews--auto-dark .gpr-review {
		background: #1e1e1e;
		border-color: #333;
	}

	.gpr-reviews--auto-dark .gpr-review__author {
		color: #e8eaed;
	}

	.gpr-reviews--auto-dark .gpr-review__text {
		color: #bdc1c6;
	}

	.gpr-reviews--auto-dark .gpr-review__rating-text,
	.gpr-reviews--auto-dark .gpr-review__date {
		color: #9aa0a6;
	}

	.gpr-reviews--auto-dark .gpr-error,
	.gpr-reviews--auto-dark .gpr-no-reviews {
		background: #2d2d2d;
		border-color: #404040;
		color: #9aa0a6;
	}
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	.gpr-reviews--cards .gpr-review {
		box-shadow: none;
		border: 1px solid #ccc;
	}

	.gpr-review__avatar {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}

	.gpr-review__stars {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.gpr-review__author:focus {
	outline: 2px solid #4285f4;
	outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
	.gpr-review {
		border-width: 2px;
	}

	.gpr-review__star--filled {
		color: #000;
	}

	.gpr-review__star--empty {
		color: #767676;
	}
}
