/**
 * Review System Styles - User Account Hub (UAH)
 */


/* ==========================================================================
   SUMMARY
   ========================================================================== */

.uah-summary {
	padding: var(--uah-spacing-xxl);
	background: var(--uah-color-bg);
	border-radius: var(--uah-radius-l);
	margin-bottom: var(--uah-spacing-xxl);
}

.uah-summary-overall {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--uah-spacing-s);
	margin-bottom: var(--uah-spacing-xl);
	background: var(--uah-color-bg-alt);
	border-radius: var(--uah-radius-l);
	padding: var(--uah-spacing-l) var(--uah-spacing-xl);
}

.uah-summary-rating {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-xl);
	text-align: center;
	min-width: 120px;
}

.uah-summary-rating-number {
	font-family: var(--uah-font-comma-base);
	font-size: var(--uah-font-size-xxxl);
	font-weight: var(--uah-weight-black);
	line-height: var(--uah-line-height-s);
	color: var(--uah-color-text);
}

.uah-summary-count {
	font-size: var(--uah-font-size-m);
	color: var(--uah-color-faded);
}

.uah-summary-rating .uah-stars {
	font-size: var(--uah-font-size-xxl);
}

.uah-distribution {
	margin-top: var(--uah-spacing-m);
}

.uah-distribution-row {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-m);
	margin-bottom: var(--uah-spacing-m);
	cursor: pointer;
	transition: opacity var(--uah-transition-fast), transform var(--uah-transition-fast);
	padding: var(--uah-spacing-xs) 0;
	border-radius: var(--uah-radius-full);
}

.uah-distribution-row:hover {
	opacity: 1 !important;
	transform: translateX(4px);
}

.uah-distribution-row:hover .uah-distribution-fill {
	background: var(--uah-color-primary);
}

.uah-distribution-row.active {
	opacity: 1 !important;
	font-weight: var(--uah-font-weight-normal);
	transform: translateX(4px);
}

.uah-distribution-row.active .uah-distribution-fill {
	background: var(--uah-color-primary);
}

.uah-distribution-label {
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-gray);
	min-width: 60px;
	transition: color var(--uah-transition-slow);
}

.uah-distribution-row.active .uah-distribution-label,
.uah-distribution-row:hover .uah-distribution-label {
	color: var(--uah-color-heading);
	transition: color var(--uah-transition-slow);
}

.uah-distribution-bar {
	flex: 1;
	height: 8px;
	background: var(--uah-color-bg-alt);
	border-radius: var(--uah-radius-s);
	overflow: hidden;
}

.uah-distribution-fill {
	height: 100%;
	background: var(--uah-color-star);
	transition: width var(--uah-transition-slow);
	width: var(--uah-fill-width, 0%);
}

.uah-distribution-stats {
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-gray);
	min-width: 120px;
	text-align: left;
	transition: color var(--uah-transition-slow);
}

.uah-distribution-row.active .uah-distribution-stats,
.uah-distribution-row:hover .uah-distribution-stats {
	color: var(--uah-color-heading);
	transition: color var(--uah-transition-slow);
}

.uah-distribution-count {
	min-width: 40px;
	text-align: right;
}

/* ==========================================================================
   LIST
   ========================================================================== */

.uah-list-container {
	width: 100%;
	margin-bottom: var(--uah-spacing-xxl);
}

.uah-list {
	display: flex;
	flex-direction: column;
	gap: var(--uah-spacing-l);
}

/* ==========================================================================
   CONTROLS
   ========================================================================== */

.uah-controls {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--uah-spacing-l);
	flex-wrap: wrap;
	margin-bottom: var(--uah-spacing-xl);
}

.uah-reviews-headline {
	margin-bottom: 0;
}

.uah-sort-buttons {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-m);
	flex-wrap: wrap;
}

.uah-sort-label {
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-faded);
	font-weight: var(--uah-weight-normal);
	margin-right: var(--uah-spacing-m);
}

.uah-sort-btn {
	padding: var(--uah-spacing-s) var(--uah-spacing-l);
	font-size: var(--uah-font-size-xs);
	background: var(--uah-color-bg);
	color: var(--uah-color-gray);
	border: 1px solid var(--uah-color-border);
	border-radius: var(--uah-radius-m);
	cursor: pointer;
	transition: all var(--uah-transition-normal);
	white-space: nowrap;
}

.uah-sort-btn:hover {
	background: var(--uah-color-bg);
	color: var(--uah-alt-color-bg);
	border: 1px solid var(--uah-alt-color-bg);
}

.uah-sort-btn-active {
	background: var(--uah-color-bg);
	color: var(--uah-alt-color-bg);
	border: 1px solid var(--uah-alt-color-bg);
}

/* ==========================================================================
   REVIEW ITEM
   ========================================================================== */

.uah-item {
	padding: var(--uah-spacing-xl);
	background: var(--uah-color-bg);
	border-radius: var(--uah-radius-l);
	border: 1px solid var(--uah-color-border);
}

.uah-item-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: var(--uah-spacing-l);
	padding-bottom: var(--uah-spacing-l);
	flex-wrap: wrap;
	gap: var(--uah-spacing-m);
	border-bottom: 1px solid var(--uah-color-border);
}

.uah-item-header-left {
	flex: 1;
	min-width: 0;
	display: flex;
	align-items: flex-start;
	gap: var(--uah-spacing-l);
}

.uah-item-avatar {
	display: flex;
	flex-shrink: 0;
}

.uah-item-avatar img {
	width: 60px;
	height: 60px;
	border-radius: var(--uah-radius-full);
	object-fit: cover;
}

.uah-item-avatar-initials {
	width: 60px;
	height: 60px;
	border-radius: var(--uah-radius-full);
	background: var(--uah-color-gray);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--uah-color-white);
	font-weight: var(--uah-font-weight-bold);
	font-size: 24px;
	text-transform: uppercase;
	user-select: none;
}

.uah-item-author-wrapper {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--uah-spacing-s);
}

.uah-item-author {
	font-size: var(--uah-font-size-xxl);
	font-weight: var(--uah-font-weight-semibold);
	color: var(--uah-color-heading);
	line-height: var(--uah-line-height-s);
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-l);
	margin-bottom: var(--uah-spacing-m);
}

/* Review Author Username with Profile Link (v5.3.0+) */
.uah-review-author-link {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-xs);
	text-decoration: none;
	transition: opacity var(--uah-transition-fast);
}

.uah-review-author-link:hover {
	opacity: 0.75;
}

/* Display Name - Prominent (v5.3.1) */
.uah-review-display-name {
	font-weight: var(--uah-font-weight-semibold);
	color: var(--uah-color-heading);
	font-size: var(--uah-font-size-m);
	margin-right: var(--uah-spacing-xs);
}

/* Username - Secondary (v5.3.1) */
.uah-review-username {
	font-weight: var(--uah-font-weight-normal);
	color: var(--uah-color-success);
	font-size: var(--uah-font-size-s);
}

/* Username Link (v5.3.1) */
.uah-review-username-link {
	text-decoration: none;
	transition: opacity var(--uah-transition-fast);
}

.uah-review-username-link:hover {
	opacity: 0.8;
	text-decoration: none;
}


.uah-item-verified {
	display: inline-block;
	font-size: var(--uah-font-size-xs);
	padding: var(--uah-spacing-s) var(--uah-spacing-m);
	background: var(--uah-color-primary);
	color: var(--uah-color-bg);
	border-radius: var(--uah-radius-m);
	font-weight: var(--uah-font-weight-normal);
}

/* Reviewer Level Badge */
.uah-reviewer-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-xs);
	font-size: var(--uah-font-size-xs);
	padding: var(--uah-spacing-s) var(--uah-spacing-m);
	border-radius: var(--uah-radius-m);
	font-weight: var(--uah-font-weight-medium);
	color: var(--uah-color-white);
}

.uah-reviewer-badge i {
	font-size: 12px;
}

/* Level-spezifische Farben */
.uah-badge-bronze {
	background: linear-gradient(135deg, var(--uah-color-bronze) 0%, #8B5A2B 100%);
}

.uah-badge-silver {
	background: linear-gradient(135deg, var(--uah-color-silver) 0%, #808080 100%);
}

.uah-badge-gold {
	background: linear-gradient(135deg, var(--uah-color-gold) 0%, #FFA500 100%);
}

.uah-badge-platinum {
	background: linear-gradient(135deg, var(--uah-color-platinum) 0%, #B8B8B8 100%);
	color: var(--uah-color-text);
}

/* Account Verified Badge */
.uah-account-verified {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-xs);
	font-size: var(--uah-font-size-xs);
	padding: var(--uah-spacing-s) var(--uah-spacing-m);
	background: var(--uah-color-success);
	color: var(--uah-color-white);
	border-radius: var(--uah-radius-m);
	font-weight: var(--uah-font-weight-medium);
}

.uah-account-verified i {
	font-size: 12px;
}

.uah-item-product {
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-faded);
	line-height: var(--uah-line-height-s);
}

.uah-item-shop {
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-faded);
	line-height: var(--uah-line-height-s);
}

.uah-item-date {
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-faded);
	white-space: nowrap;
}

.uah-item-rating {
	margin-bottom: var(--uah-spacing-l);
	display: flex;
	flex-direction: column;
	gap: var(--uah-spacing-s);
}

.uah-item-rating-stars {
	display: flex;
	gap: var(--uah-spacing-m);
	align-items: center;
}

.uah-stars {
	display: inline-flex;
	gap: var(--uah-spacing-s);
	font-size: var(--uah-font-size-l);
}

.uah-stars .fas.fa-star,
.uah-stars .fas.fa-star-half-alt {
	color: var(--uah-color-star);
}

.uah-stars .far.fa-star {
	color: var(--uah-color-gray);
}

.uah-item-rating-value {
	font-size: var(--uah-font-size-l);
	font-weight: var(--uah-font-weight-semibold);
	color: var(--uah-color-heading);
}

.uah-item-rating-details {
	display: flex;
	gap: var(--uah-spacing-l);
	font-size: var(--uah-font-size-m);
	color: var(--uah-color-faded);
	flex-wrap: wrap;
	line-height: var(--uah-line-height-s);
}

.uah-item-text {
	margin-bottom: var(--uah-spacing-l);
	line-height: var(--uah-line-height-relaxed);
	color: var(--uah-color-text);
}

.uah-item-images {
	display: flex;
	gap: var(--uah-spacing-s);
	flex-wrap: wrap;
}

.uah-item-image {
	display: block;
	cursor: pointer;
}

.uah-item-image a {
	display: flex;
}

.uah-item-image img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: var(--uah-radius-m);
	border: 1px solid var(--uah-color-border);
	transition: all var(--uah-transition-normal);
}

.uah-item-image:hover img {
	border: 1px solid var(--uah-color-primary);
}

.uah-item-admin-response {
	padding: var(--uah-spacing-xxl) var(--uah-spacing-xl);
	background: var(--uah-color-bg-alt);
	border-radius: var(--uah-radius-l);
	margin-top: var(--uah-spacing-l);
}

.uah-item-admin-label {
	font-weight: var(--uah-font-weight-semibold);
	color: var(--uah-color-text);
	margin-bottom: var(--uah-spacing-s);
	font-size: var(--uah-font-size-base);
}

.uah-item-admin-text {
	font-size: var(--uah-font-size-m);
	color: var(--uah-color-text);
	line-height: var(--uah-line-height-relaxed);
}

/* Vote Buttons Footer (v5.0.0+: Helpful + Not Helpful) */
.uah-item-footer {
	display: flex;
	gap: var(--uah-spacing-m);
	align-items: center;
	padding-top: var(--uah-spacing-l);
}

/* Base styles for both vote buttons */
.uah-helpful-btn,
.uah-not-helpful-btn {
	background: var(--uah-color-bg-alt);
	border: 1px solid var(--uah-color-border);
	color: var(--uah-color-faded);
	cursor: pointer;
	padding: var(--uah-spacing-m) var(--uah-spacing-l);
	border-radius: var(--uah-radius-m);
	transition: all var(--uah-transition-normal);
	font-size: var(--uah-font-size-s);
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-xs);
}

/* Helpful button hover */
.uah-helpful-btn:hover:not(.uah-helpful-voted) {
	background: #f1f8f1;
	color: var(--uah-color-success);
	border-color: var(--uah-color-success);
}

/* Not Helpful button hover */
.uah-not-helpful-btn:hover:not(.uah-not-helpful-voted) {
	background: #fff5f5;
	color: var(--uah-color-error);
	border-color: var(--uah-color-error);
}

/* Voted states (active) */
.uah-helpful-voted {
	background: var(--uah-color-success) !important;
	color: var(--uah-color-white) !important;
	border-color: var(--uah-color-success) !important;
}

.uah-not-helpful-voted {
	background: var(--uah-color-error) !important;
	color: var(--uah-color-white) !important;
	border-color: var(--uah-color-error) !important;
}

/* Keep hover effect even when voted (for toggle-off) */
.uah-helpful-voted:hover {
	opacity: 0.8;
	cursor: pointer;
}

.uah-not-helpful-voted:hover {
	opacity: 0.8;
	cursor: pointer;
}

/* Icon spacing */
.uah-helpful-btn i,
.uah-not-helpful-btn i {
	margin-right: var(--uah-spacing-xs);
}

/* Loading state for vote buttons (v5.0.2+) */
.uah-helpful-btn:disabled,
.uah-not-helpful-btn:disabled {
	cursor: not-allowed;
	opacity: 0.7;
}

.uah-helpful-btn .uah-btn-loader,
.uah-not-helpful-btn .uah-btn-loader {
	display: none;
}

.uah-helpful-btn:disabled .uah-btn-text,
.uah-not-helpful-btn:disabled .uah-btn-text {
	display: none;
}

.uah-helpful-btn:disabled .uah-vote-count,
.uah-not-helpful-btn:disabled .uah-vote-count {
	display: none;
}

.uah-helpful-btn:disabled .uah-btn-loader,
.uah-not-helpful-btn:disabled .uah-btn-loader {
	display: inline;
}

/* ==========================================================================
   FORM
   ========================================================================== */

.uah-form-group {
	margin-bottom: var(--uah-spacing-xxl);
}

.uah-form-label {
	display: block;
	margin-bottom: var(--uah-spacing-m);
	font-weight: var(--uah-font-weight-normal);
	color: var(--uah-color-text);
}

.star-rating-form-group {
	background: var(--uah-color-bg);
	padding: var(--uah-spacing-xxl);
	border: 1px solid var(--uah-color-border);
	border-radius: var(--uah-radius-m);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	gap: var(--uah-spacing-xxl);
}

.uah-rating-group {
	display: flex;
	flex-direction: column;
	gap: var(--uah-spacing-s);
}

.uah-rating-label {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-s);
	font-size: var(--uah-font-size-m);
	color: var(--uah-color-faded);
}

.uah-rating-label i {
	color: var(--uah-color-primary);
	font-size: var(--uah-font-size-l);
}

.uah-star-input,
.uah-star-input {
	display: inline-flex;
	gap: var(--uah-spacing-xs);
	cursor: pointer;
	line-height: var(--uah-line-height-s);
}

.uah-star-input .star,
.uah-star-input .star {
	font-size: var(--uah-font-size-xxl);
	color: var(--uah-color-gray);
	transition: all var(--uah-transition-fast);
	cursor: pointer;
}

.uah-star-input .star.active,
.uah-star-input .star.active {
	color: var(--uah-color-star);
}

.uah-star-input .star:hover,
.uah-star-input .star:hover {
	transform: scale(1.2);
}

select.uah-form-control {
	cursor: pointer;
}

.review-product-select .uah-form-control {
	max-width: 280px;
}

textarea.uah-form-control {
	resize: vertical;
	min-height: 222px;
	padding: var(--uah-spacing-xxl);
}

.uah-form-hint {
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-gray);
	margin-top: var(--uah-spacing-m);
	line-height: var(--uah-line-height-s);
	padding-left: var(--uah-spacing-m);
}

.uah-form-hint .fa-check-circle {
	color: var(--uah-color-primary);
}

.author-wrapper {
	display: flex;
	justify-content: space-between;
	gap: var(--uah-spacing-l);
}

.author-wrapper .uah-form-group {
	width: 50%;
}

.uah-form-group.mb-0 {
	margin-bottom: 0;
}

/* ==========================================================================
   IMAGE PREVIEW/UPLOAD
   ========================================================================== */

.uah-image-preview {
	display: flex;
	flex-wrap: wrap;
	gap: var(--uah-spacing-s);
	margin-top: var(--uah-spacing-l);
}

.uah-image-preview-item {
	position: relative;
	display: inline-block;
}

.uah-image-preview-item img {
	display: block;
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: var(--uah-radius-m);
	border: 1px solid var(--uah-color-border);
}

.uah-image-remove {
	position: absolute;
	z-index: 111;
	top: -5px;
	right: -5px;
	width: 25px;
	height: 25px;
	border-radius: var(--uah-radius-full);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--uah-alt-color-bg);
	background: var(--uah-color-bg);
	color: var(--uah-color-heading);
	cursor: pointer;
	font-size: 20px;
	line-height: 20px;
	transition: all var(--uah-transition-fast);
}

.uah-image-remove:hover {
	background: var(--uah-color-bg);
	color: var(--uah-color-error);
	border: 1px solid var(--uah-color-error);
	transform: scale(1.1);
}

/* File Upload Button */
.uah-file-select-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-s);
	margin-bottom: var(--uah-spacing-s);
}

.uah-selected-file {
	display: inline-block;
	margin-left: var(--uah-spacing-m);
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-text);
	font-style: italic;
}

/* ==========================================================================
   CONSENT CHECKBOX (AGB/DATENSCHUTZ)
   ========================================================================== */

.uah-consent-wrapper {
	display: flex;
	align-items: flex-start;
	gap: var(--uah-spacing-m);
	align-items: center;
	margin-top: var(--uah-spacing-l);
}

.uah-consent-checkbox {
	margin: 0 !important;
}

.uah-consent-label {
	flex: 1;
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-faded);
	line-height: var(--uah-line-height-s);
	cursor: pointer;
	user-select: none;
}

.uah-consent-label a {
	color: var(--uah-color-faded);
	text-decoration: underline;
	transition: color var(--uah-transition-fast);
}

.uah-consent-label a:hover {
	color: var(--uah-color-primary);
}

/* ========================================================================
   LOGIN PROMPT
   ======================================================================== */

.uah-login-prompt {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-m);
	padding: var(--uah-spacing-l);
	margin-bottom: var(--uah-spacing-l);
	background: var(--uah-color-bg);
	border: 1px solid var(--uah-color-border);
	border-radius: var(--uah-radius-m);
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-heading);
}

.uah-login-prompt i {
	flex-shrink: 0;
	color: var(--uah-color-star);
}

.uah-login-prompt a {
	color: var(--uah-color-primary);
	font-weight: var(--uah-font-weight-semibold);
	text-decoration: underline;
}

.uah-login-prompt a:hover {
	color: var(--uah-color-secondary);
}

/* ========================================================================
   MODAL STYLES (Shared UI Component - supports both pcr and uah prefixes)
   ======================================================================== */

.uah-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: var(--uah-z-popup, 99999);
	display: flex;
	align-items: center;
	justify-content: center;
}

.uah-modal-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.85);
	backdrop-filter: blur(8px);
}

.uah-modal-content {
	position: relative;
	background: var(--uah-color-bg);
	border-radius: var(--uah-radius-l);
	max-width: 500px;
	width: 90%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: var(--uah-shadow-xl);
	z-index: calc(var(--uah-z-popup, 99999) + 1);
}

.uah-modal-close {
	position: absolute;
	top: var(--uah-spacing-m);
	right: var(--uah-spacing-m);
	background: transparent;
	border: none;
	font-size: var(--uah-font-size-l);
	color: var(--uah-color-heading);
	cursor: pointer;
	transition: color var(--uah-transition-fast, 0.15s ease);
	z-index: 10;
}

.uah-modal-close:hover {
	color: var(--uah-color-error);
}

.uah-modal-header {
	padding: var(--uah-spacing-xxl) var(--uah-spacing-l);
	background: var(--uah-color-bg);
	color: var(--uah-color-heading);
	text-align: center;
}

.uah-modal-title {
	font-size: var(--uah-font-size-xl);
	font-weight: var(--uah-font-weight-semibold);
	line-height: var(--uah-line-height-s);
	margin-bottom: var(--uah-spacing-m);
}

.uah-modal-header .uah-login-subline {
	font-size: var(--uah-font-size-s);
	font-weight: var(--uah-font-weight-norma);
	color: var(--uah-color-faded);
	line-height: var(--uah-line-height-s);
}

.uah-modal-tabs {
	display: flex;
	background: var(--uah-color-bg-alt);
}

.uah-modal-tabs .uah-tab-btn {
	flex: 1;
	padding: var(--uah-spacing-l) var(--uah-spacing-m);
	background: none;
	cursor: pointer;
	font-size: var(--uah-font-size-m);
	font-weight: var(--uah-font-weight-normal);
	color: var(--uah-color-gray);
	transition: all var(--uah-transition-normal);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	bottom: -1px;
}

.uah-modal-tabs .uah-tab-btn:hover {
	color: var(--uah-color-heading);
	font-weight: var(--uah-font-weight-semibold);
}

.uah-modal-tabs .uah-tab-btn.uah-tab-active {
	background: var(--uah-color-bg);
	color: var(--uah-color-heading);
	font-weight: var(--uah-font-weight-semibold);
}

.uah-tab-content {
	display: none;
}

.uah-tab-content.uah-tab-active {
	display: block;
}

.uah-modal-body {
	padding: var(--uah-spacing-xxl) var(--uah-spacing-xl);
}

.uah-modal-body .uah-form-group {
	margin-bottom: var(--uah-spacing-l);
}

.uah-modal-body .uah-form-label {
	margin-bottom: var(--uah-spacing-m);
	font-weight: var(--uah-weight-normal);
	color: var(--uah-color-heading);
	font-size: var(--uah-font-size-s);
	display: flex;
	align-items: center;
}

body.uah-modal-open {
	overflow: hidden;
}

.uah-form-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--uah-spacing-l);
}

.uah-checkbox-label {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-xs);
	cursor: pointer;
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-faded);
	margin: 0;
	font-weight: var(--uah-font-weight-light);
}

.uah-link {
	color: var(--uah-color-faded);
	text-decoration: none;
	font-size: var(--uah-font-size-xs);
	font-weight: var(--uah-font-weight-light);
	transition: color var(--uah-transition-normal);
}

.uah-link:hover {
	color: var(--uah-color-primary);
	text-decoration: underline;
}

.uah-modal-body .uah-spam-label {
	font-size: var(--uah-font-size-xs);
	color: var(--uah-color-faded);
	margin-top: var(--uah-spacing-s);
	font-weight: var(--uah-font-weight-light);
}

.uah-modal-body .uah-spam-label a {
	text-decoration: underline;
	color: var(--uah-color-faded);
}

.uah-btn-block {
	width: 100%;
}

/* ==========================================================================
   LOAD MORE
   ========================================================================== */

.uah-load-more-container {
	text-align: center;
	margin-top: var(--uah-spacing-l);
}

.uah-load-more-btn {
	padding: var(--uah-spacing-l) var(--uah-spacing-xxl);
	background: var(--uah-alt-color-bg);
	font-size: var(--uah-font-size-m);
	color: var(--uah-alt-color-heading);
	line-height: var(--uah-line-height-s);
	font-weight: var(--uah-font-weight-normal);
	border-radius: var(--uah-radius-m);
	transition: all var(--uah-transition-slow);
}

.uah-load-more-btn:hover {
	background: var(--uah-color-primary);
	transition: all var(--uah-transition-slow);
}

.uah-btn-text {
	display: inline;
}

.uah-btn-loader {
	display: none;
}

.uah-load-more-btn:disabled .uah-btn-text {
	display: none;
}

.uah-load-more-btn:disabled .uah-btn-loader {
	display: inline;
}

/* ==========================================================================
   LOADING/ERROR STATES
   ========================================================================== */

.uah-loading {
	text-align: center;
	padding: var(--uah-spacing-xl);
	color: var(--uah-color-faded);
}

.uah-error {
	text-align: center;
	padding: var(--uah-spacing-xl);
	color: var(--uah-color-secondary);
}

.uah-no-reviews {
	text-align: center;
	padding: var(--uah-spacing-xl);
	color: var(--uah-color-faded);
}

/* ==========================================================================
   IMAGE LIGHTBOX
   ========================================================================== */

.uah-lightbox {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: var(--uah-z-lightbox);
	opacity: 0;
	transition: opacity var(--uah-transition-slow);
}

.uah-lightbox-active {
	opacity: 1;
}

.uah-lightbox-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.8);
	cursor: pointer;
}

.uah-lightbox-content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 90vw;
	max-height: 90vh;
	z-index: calc(var(--uah-z-lightbox) + 1);
}

.uah-lightbox-content img {
	max-width: 100%;
	max-height: 90vh;
	object-fit: contain;
	border-radius: var(--uah-radius-l);
	box-shadow: var(--uah-shadow-xl);
	transition: opacity 0.15s ease;
}

.uah-lightbox-close {
	position: absolute;
	top: 10px;
	right: 10px;
	line-height: 35px;
	color: var(--uah-color-heading);
	background: none;
	border-radius: var(--uah-radius-full);
	font-size: 32px;
	cursor: pointer;
	transition: all var(--uah-transition-normal);
	z-index: 10;
}

.uah-lightbox-close:hover {
	color: var(--uah-color-error);
}

.uah-lightbox-prev,
.uah-lightbox-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 35px;
	height: 35px;
	color: var(--uah-color-heading);
	border: none;
	border-radius: var(--uah-radius-full);
	font-size: 32px;
	cursor: pointer;
	transition: all var(--uah-transition-normal);
	z-index: 10;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.uah-lightbox-prev {
	left: -60px;
}

.uah-lightbox-next {
	right: -60px;
}

.uah-lightbox-prev:hover,
.uah-lightbox-next:hover {
	transform: translateY(-50%) scale(1.1);
}

.uah-lightbox-counter {
	position: absolute;
	bottom: -40px;
	left: 50%;
	transform: translateX(-50%);
	color: var(--uah-alt-color-text);
	background: var(--uah-alt-color-bg);
	padding: var(--uah-spacing-xs) var(--uah-spacing-l);
	border-radius: var(--uah-radius-m);
	font-size: var(--uah-font-size-m);
	white-space: nowrap;
}

/* ==========================================================================
   RESPONSIVE BREAKPOINTS
   ========================================================================== */

/* Tablet: 768px */
@media (max-width: 768px) {
	.uah-summary-overall {
		flex-direction: column;
		text-align: center;
	}

	.uah-controls {
		flex-direction: column;
		align-items: stretch;
	}

	.uah-sort-buttons {
		justify-content: center;
	}

	.uah-item-header {
		flex-direction: column;
	}

	.uah-item-avatar img,
	.uah-item-avatar-initials {
		width: 40px;
		height: 40px;
		font-size: 18px;
	}

	.uah-item-rating-details {
		flex-direction: column;
		gap: 0.125rem;
	}

	.uah-star-input .star,
	.uah-star-input .star {
		font-size: var(--uah-font-size-l);
	}

	.uah-modal-content {
		width: 95%;
		max-width: 100%;
	}
}

/* Mobile: 640px */
@media (max-width: 640px) {
	.uah-form-control {
		font-size: 16px;
		/* Prevent zoom on iOS */
	}

	.uah-sort-btn {
		font-size: var(--uah-font-size-xs);
		padding: 0.125rem 0.5rem;
	}

	.uah-summary {
		padding: 1rem;
	}

	.uah-item {
		padding: 1rem;
	}

	.uah-item-avatar img,
	.uah-item-avatar-initials {
		width: 32px;
		height: 32px;
		font-size: 14px;
	}

	/* Lightbox navigation on mobile */
	.uah-lightbox-prev {
		left: 10px;
	}

	.uah-lightbox-next {
		right: 10px;
	}

	.uah-lightbox-prev,
	.uah-lightbox-next {
		width: 40px;
		height: 40px;
		font-size: 30px;
	}

	.uah-lightbox-close {
		top: 10px;
		right: 10px;
	}

	.uah-lightbox-counter {
		bottom: 10px;
	}
}

/* ==========================================================================
   REVIEW CTA WITH RATING & TOOLTIP
   ========================================================================== */

.uah-review-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-m);
}

.uah-review-cta-rating {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-s);
}

.uah-cta-rating-value {
	font-size: var(--uah-font-size-m);
	font-weight: var(--uah-font-weight-semibold);
	color: var(--uah-color-heading);
}

.uah-cta-stars {
	display: inline-flex;
}

.uah-cta-stars .uah-stars {
	font-size: var(--uah-font-size-m);
	gap: 2px;
}

/* Tooltip */
.uah-cta-tooltip {
	display: none;
	position: absolute;
	bottom: calc(100% + 12px);
	left: 50%;
	transform: translateX(-50%);
	background: var(--uah-color-tooltip-dark-bg);
	color: var(--uah-color-tooltip-text);
	border-radius: var(--uah-radius-m);
	padding: var(--uah-spacing-l);
	min-width: 280px;
	z-index: var(--uah-z-tooltip);
	box-shadow: var(--uah-shadow-xl);
	opacity: 0;
	pointer-events: none;
}

.uah-cta-tooltip.show {
	display: block;
	animation: uah-tooltip-fade-in 0.3s forwards;
	pointer-events: auto;
}

/* Tooltip Arrow */
.uah-cta-tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 8px solid transparent;
	border-top-color: var(--uah-color-tooltip-dark-bg);
}

/* Tooltip Header */
.uah-cta-tooltip-header {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--uah-spacing-xs);
}

.uah-cta-tooltip-rating {
	font-size: var(--uah-font-size-xxl);
	font-weight: var(--uah-font-weight-black);
	font-family: var(--uah-font-comma-base);
}

.uah-cta-tooltip-title {
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-gray);
	margin-bottom: var(--uah-spacing-m);
	text-align: center;
}

/* Tooltip Distribution Rows */
.uah-cta-tooltip-row {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-s);
	margin-bottom: var(--uah-spacing-s);
}

.uah-cta-tooltip-row:last-child {
	margin-bottom: 0;
}

.uah-cta-tooltip-row-empty {
	opacity: 0.4;
}

.uah-cta-tooltip-stars-label {
	font-size: var(--uah-font-size-xs);
	min-width: 60px;
	color: var(--uah-color-tooltip-text);
}

.uah-cta-tooltip-bar {
	flex: 1;
	height: 8px;
	background: var(--uah-color-bg-alt);
	border-radius: var(--uah-radius-s);
	overflow: hidden;
}

.uah-cta-tooltip-fill {
	height: 100%;
	background: var(--uah-color-star);
	transition: width var(--uah-transition-slow);
}

.uah-cta-tooltip-percent {
	font-size: var(--uah-font-size-xs);
	min-width: 40px;
	text-align: right;
	color: var(--uah-color-tooltip-text);
}

/* Fade-in Animation */
@keyframes uah-tooltip-fade-in {
	from {
		opacity: 0;
		transform: translateX(-50%) translateY(4px);
	}
	to {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
	}
}

/* Responsive: Mobile/Tablet */
@media (max-width: 768px) {
	.uah-cta-tooltip {
		min-width: 240px;
		font-size: var(--uah-font-size-xs);
	}

	.uah-cta-tooltip-rating {
		font-size: var(--uah-font-size-xl);
	}

	.uah-cta-tooltip-title {
		font-size: var(--uah-font-size-xxs);
	}

	.uah-cta-tooltip-stars-label,
	.uah-cta-tooltip-percent {
		font-size: var(--uah-font-size-xxs);
		min-width: 50px;
	}
}

/* ==========================================================================
   TAXONOMY FIELDS & CHIPS (v5.0.3+)
   ========================================================================== */

/* Taxonomy Checkbox List (Form) */
.uah-taxonomy-checkbox-list {
	display: flex;
	flex-direction: column;
	gap: var(--uah-spacing-s);
	max-height: 250px;
	overflow-y: auto;
	padding: var(--uah-spacing-m);
	border: 1px solid var(--uah-color-border);
	border-radius: var(--uah-radius-s);
	background: var(--uah-color-bg-alt);
}

.uah-checkbox-item {
	display: flex;
	align-items: center;
	gap: var(--uah-spacing-s);
	padding: var(--uah-spacing-xs) var(--uah-spacing-s);
	cursor: pointer;
	transition: background-color var(--uah-transition-fast);
	border-radius: var(--uah-radius-s);
}

.uah-checkbox-item:hover {
	background-color: rgba(0, 0, 0, 0.04);
}

.uah-taxonomy-checkbox {
	width: 18px;
	height: 18px;
	min-width: 18px;
	cursor: pointer;
	accent-color: var(--uah-color-primary, #007cba);
	margin: 0;
}

.uah-checkbox-label {
	margin: 0;
	cursor: pointer;
	user-select: none;
	font-size: 14px;
	line-height: 1.4;
	color: var(--uah-text-primary, #333);
	flex: 1;
}

/* Taxonomy Chips Display (Review Item) */
.uah-item-taxonomies,
.uah-review-taxonomies {
	display: flex;
	flex-wrap: wrap;
	gap: var(--uah-spacing-xs);
	margin-top: var(--uah-spacing-md);
	padding-top: var(--uah-spacing-md);
	border-top: 1px solid var(--uah-border-color);
}

.uah-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--uah-spacing-xxs);
	padding: var(--uah-spacing-xs) var(--uah-spacing-sm);
	background: var(--uah-color-bg-alt);
	border-radius: var(--uah-radius-s);
	font-size: var(--uah-font-size-s);
	color: var(--uah-color-text);
	line-height: 1.4;
	white-space: nowrap;
	border: 1px solid var(--uah-color-border);
	transition: all var(--uah-transition-fast);
}

.uah-chip:hover {
	background: var(--uah-bg-tertiary, #e0e0e0);
	transform: translateY(-1px);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.uah-chip-icon {
	width: 16px;
	height: 16px;
	object-fit: contain;
	flex-shrink: 0;
}

/* Responsive Design */
@media (max-width: 768px) {
	.uah-taxonomy-select {
		min-height: 80px;
		font-size: var(--uah-font-size-sm);
	}

	.uah-item-taxonomies,
	.uah-review-taxonomies {
		margin-top: var(--uah-spacing-sm);
		padding-top: var(--uah-spacing-sm);
	}

	.uah-chip {
		font-size: var(--uah-font-size-xs);
		padding: var(--uah-spacing-xs) var(--uah-spacing-s);
	}

	.uah-chip-icon {
		width: 14px;
		height: 14px;
	}
}