/* ==========================================================================
   Reviews / Referenzen — Hero, Sidebar-Filter, Karten-Liste, CTA
   ========================================================================== */

.rv-page { padding-bottom: 0; }

/* --- Hero (analog zur Support-/Such-Hero: Hintergrundbild links, zentrierter Text) --- */
.rv-hero {
	position: relative;
	background: linear-gradient(180deg, var(--pw-bg-alt) 0%, #fff 100%);
	padding: var(--pw-section-hero);
	text-align: center;
	overflow: hidden;
}
.rv-hero__bgimage {
	position: absolute;
	left: 8%;
	bottom: 0;
	width: 560px;
	height: auto;
	opacity: 0.08;
	pointer-events: none;
	user-select: none;
	z-index: 0;
}
.rv-hero .pw-container {
	position: relative;
	z-index: 1;
}
.rv-hero__eyebrow {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--pw-brand);
	margin: 0 0 12px;
}
.rv-hero__title {
	font-size: 44px;
	font-weight: 700;
	color: var(--pw-text);
	margin: 0 0 12px;
	letter-spacing: -0.03em;
	line-height: 1.15;
}
.rv-hero__sub {
	font-size: 18px;
	color: var(--pw-text-secondary);
	margin: 0 auto var(--pw-space-xl);
	max-width: 720px;
	line-height: 1.5;
}
.rv-hero__search {
	display: flex;
	align-items: center;
	gap: 12px;
	max-width: 720px;
	margin: 0 auto var(--pw-space-lg);
	padding: 0 18px;
	min-height: 56px;
	background: var(--pw-bg);
	border: 1px solid var(--pw-border);
	border-radius: var(--pw-radius-md);
	color: var(--pw-text-muted);
	transition: border-color 0.2s, box-shadow 0.2s;
}
.rv-hero__search:focus-within {
	border-color: var(--pw-brand);
	box-shadow: 0 0 0 4px rgba(var(--pw-brand-rgb),0.12);
}
.rv-hero__search input {
	flex: 1;
	background: transparent;
	border: none;
	outline: none;
	font: inherit;
	font-size: 16px;
	color: var(--pw-text);
	min-width: 0;
}
.rv-hero__search input::placeholder { color: var(--pw-text-muted); }
@media (prefers-color-scheme: dark) {
	.rv-hero__search { background: var(--pw-dark-2); border-color: var(--pw-dark-3); }
	.rv-hero__search input { color: var(--pw-fg); }
}
@media (max-width: 900px) {
	.rv-hero__bgimage { width: 340px; left: 2%; opacity: 0.1; }
}
@media (prefers-color-scheme: dark) {
	.rv-hero { background: linear-gradient(180deg, #0a0a0a 0%, #111 100%); }
	.rv-hero__bgimage { opacity: 0.18; filter: invert(1); }
}

/* --- Layout (Sidebar links, Liste rechts) --- */
.rv-layout {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: var(--pw-space-2xl);
	align-items: start;
	margin-top: var(--pw-space-lg);
}
.rv-aside {
	position: sticky;
	/* 80px = 60px sticky-Header + 20px Atemspielraum */
	top: 80px;
}
.rv-main { min-width: 0; }

/* --- Status-Anzeige (Treffer-Anzahl) --- */
.rv-toolbar__status {
	font-size: 13px;
	color: var(--pw-text-muted);
	margin: 0 0 var(--pw-space-md);
	font-variant-numeric: tabular-nums;
}
.rv-toolbar__status:empty { display: none; }

/* --- Filter-Sidebar --- */
.rv-filters {
	display: flex;
	flex-direction: column;
	gap: var(--pw-space-lg);
}
.rv-filters__row {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.rv-filters__label {
	font-size: 11px;
	font-weight: 700;
	color: var(--pw-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: var(--pw-space-xs);
}
.rv-filters__reset {
	display: inline-flex;
	align-items: center;
	gap: var(--pw-space-xs);
	padding: 6px 0;
	font-size: 13px;
	font-weight: 600;
	color: var(--pw-text-muted);
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
	align-self: flex-start;
	transition: color 0.15s;
}
.rv-filters__reset:hover { color: var(--pw-brand); }

/* --- Chips --- */
.rv-chips {
	display: flex;
	flex-direction: column;
	gap: var(--pw-space-xs);
}
.rv-chips--scroll {
	max-height: 280px;
	overflow-y: auto;
	padding-right: var(--pw-space-xs);
}
.rv-chip {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 9px 14px;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--pw-radius-sm);
	font-size: 14px;
	font-weight: 500;
	color: var(--pw-text);
	transition: background 0.15s, color 0.15s, border-color 0.15s;
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	width: 100%;
}
.rv-chip:hover {
	background: var(--pw-bg-alt);
	color: var(--pw-text);
}
.rv-chip.is-active {
	background: #fff4e6;
	border-color: #fcd9b2;
	color: var(--pw-brand);
	font-weight: 600;
}
.rv-chip.is-active:hover { background: #ffe8d1; color: var(--pw-brand); }
.rv-chip--disabled,
.rv-chip[disabled] {
	color: var(--pw-border-light);
	pointer-events: none;
	cursor: default;
	background: transparent;
	border-color: transparent;
}
.rv-chip--disabled:hover,
.rv-chip[disabled]:hover {
	background: transparent;
	color: var(--pw-border-light);
	border-color: transparent;
}
.rv-chip--disabled .rv-chip__stars,
.rv-chip[disabled] .rv-chip__stars,
.rv-chip--disabled .rv-chip__stars-empty,
.rv-chip[disabled] .rv-chip__stars-empty {
	color: var(--pw-border-light);
}
.rv-chip__label { flex: 1; min-width: 0; }
.rv-chip__count {
	font-size: 12px;
	font-weight: 500;
	color: var(--pw-text-muted);
	font-variant-numeric: tabular-nums;
}
.rv-chip.is-active .rv-chip__count { color: var(--pw-brand); }
.rv-chip--disabled .rv-chip__count { color: var(--pw-border-light); }
.rv-chip__stars { color: #ffb400; letter-spacing: 1.5px; font-size: 13px; }
.rv-chip__stars-empty { color: var(--pw-border-light); }
.rv-chip.is-active .rv-chip__stars { color: var(--pw-brand); }
.rv-chip--topic { font-size: 13px; padding: 7px 12px; }

@media (prefers-color-scheme: dark) {
	.rv-chip { color: var(--pw-fg); }
	.rv-chip:hover { background: var(--pw-dark-3); }
	.rv-chip.is-active {
		background: rgba(var(--pw-brand-rgb),0.15);
		border-color: rgba(var(--pw-brand-rgb),0.3);
		color: var(--pw-brand-hover);
	}
	.rv-chip.is-active:hover { background: rgba(var(--pw-brand-rgb),0.2); color: var(--pw-brand-hover); }
	.rv-chip.is-active .rv-chip__count { color: var(--pw-brand-hover); }
	.rv-chip__stars-empty { color: rgba(255,255,255,0.15); }
	.rv-chip--disabled,
	.rv-chip[disabled] { color: #3a3a3a; }
	.rv-chip--disabled .rv-chip__count,
	.rv-chip[disabled] .rv-chip__count { color: #3a3a3a; }
	.rv-chip--disabled .rv-chip__stars,
	.rv-chip[disabled] .rv-chip__stars,
	.rv-chip--disabled .rv-chip__stars-empty,
	.rv-chip[disabled] .rv-chip__stars-empty { color: #3a3a3a; }
}

/* --- Topic-Tag-Bar (oberhalb der Liste) --- */
.rv-tagbar {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin: 0 0 var(--pw-space-lg);
	flex-wrap: wrap;
}
.rv-tagbar__label {
	font-size: 11px;
	font-weight: 700;
	color: var(--pw-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding-top: 6px;
	flex-shrink: 0;
}
.rv-tagbar__list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	flex: 1;
	min-width: 0;
}
.rv-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 5px 12px;
	border-radius: var(--pw-radius-pill);
	background: var(--pw-bg-alt);
	border: 1px solid transparent;
	color: var(--pw-text-secondary);
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.15s;
	white-space: nowrap;
	font-family: inherit;
	line-height: 1.3;
}
.rv-tag[hidden] { display: none; }
.rv-chip[hidden] { display: none; }
.rv-tag:hover {
	background: var(--pw-border);
	color: var(--pw-text);
}
.rv-tag.is-active {
	background: var(--pw-brand);
	color: #fff;
	border-color: var(--pw-brand);
}
.rv-tag__count {
	font-size: 10px;
	opacity: 0.7;
	font-variant-numeric: tabular-nums;
}
@media (prefers-color-scheme: dark) {
	.rv-tag { color: var(--pw-text-secondary); }
	.rv-tag:hover { background: var(--pw-dark-3); color: var(--pw-fg); }
}

/* --- Liste / Karten --- */
.rv-list-section {
	padding-bottom: 64px;
}
.rv-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--pw-space-md);
}
.rv-card {
	background: var(--pw-bg);
	border: 1px solid var(--pw-border);
	border-radius: var(--pw-radius-md);
	padding: var(--pw-space-lg);
	display: flex;
	flex-direction: column;
	min-height: 260px;
	transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
	cursor: pointer;
}
.rv-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--pw-shadow-md);
	border-color: var(--pw-border-light);
}
.rv-card[hidden] { display: none; }
.rv-card__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 12px;
}
.rv-card__source {
	display: inline-block;
	padding: 3px 10px;
	border-radius: var(--pw-radius-pill);
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.rv-card__source--appstore  { background: #eaf3fa; color: var(--pw-link); }
.rv-card__source--capterra  { background: #fff4e6; color: var(--pw-brand); }
.rv-card__source--reference { background: #e6f6ea; color: #2c8a3f; }
.rv-card__stars {
	color: #ffb400;
	font-size: 13px;
	letter-spacing: 1.5px;
}
.rv-card__stars-empty { color: var(--pw-border-light); }
.rv-card__date {
	display: block;
	font-size: 11px;
	color: var(--pw-text-muted);
	margin: 0 0 10px;
	font-variant-numeric: tabular-nums;
}
.rv-card__title {
	font-size: 15px;
	font-weight: 700;
	color: var(--pw-text);
	margin: 0 0 var(--pw-space-sm);
	line-height: 1.35;
}
.rv-card__body {
	font-size: 14px;
	line-height: 1.6;
	color: var(--pw-text-secondary);
	margin: 0 0 auto;
	padding-bottom: var(--pw-space-md);
}
.rv-card__foot {
	display: flex;
	flex-direction: column;
	gap: 2px;
	margin-top: auto;
	padding-top: var(--pw-space-xs);
}
.rv-card__author {
	font-size: 13px;
	color: var(--pw-text-muted);
	font-weight: 400;
}
.rv-card__meta {
	font-size: 12px;
	color: var(--pw-text-muted);
}
.rv-list__empty {
	text-align: center;
	padding: var(--pw-space-2xl) var(--pw-space-md);
	color: var(--pw-text-muted);
	font-size: 15px;
	grid-column: 1 / -1;
}

@media (prefers-color-scheme: dark) {
	.rv-card__source--appstore  { background: rgba(42,127,191,0.15); color: var(--pw-accent); }
	.rv-card__source--capterra  { background: rgba(var(--pw-brand-rgb),0.15); color: var(--pw-brand-hover); }
	.rv-card__source--reference { background: rgba(52,199,89,0.15); color: #4ade80; }
	.rv-card__stars-empty       { color: rgba(255,255,255,0.15); }
}

/* --- CTA --- */
.rv-cta {
	padding: 0 0 var(--pw-space-3xl);
}
.rv-cta__box {
	background: var(--pw-bg-alt);
	border-radius: var(--pw-radius-lg);
	padding: 56px var(--pw-space-xl);
	text-align: center;
}
.rv-cta__title {
	font-size: clamp(22px, 2.4vw, 28px);
	letter-spacing: -0.02em;
	color: var(--pw-text);
	margin: 0 0 12px;
}
.rv-cta__sub {
	font-size: 16px;
	color: var(--pw-text-secondary);
	margin: 0 auto var(--pw-space-lg);
	max-width: 640px;
	line-height: 1.6;
}
.rv-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: var(--pw-space-sm);
	padding: 14px 28px;
	background: var(--pw-brand);
	color: #fff;
	border-radius: var(--pw-radius-md);
	font-weight: 600;
	font-size: 16px;
	transition: background 0.2s, transform 0.2s;
}
.rv-cta__btn:hover {
	background: var(--pw-brand-hover);
	color: #fff;
	transform: translateY(-1px);
}

/* --- Responsive --- */
@media (max-width: 900px) {
	.rv-layout {
		grid-template-columns: 1fr;
		gap: var(--pw-space-lg);
		margin-top: var(--pw-space-md);
	}
	.rv-aside { position: static; }
	.rv-filters {
		flex-direction: row;
		flex-wrap: wrap;
		gap: var(--pw-space-md) var(--pw-space-lg);
	}
	.rv-filters__row { flex: 1 1 240px; }
	.rv-chips--scroll { max-height: 180px; }
}
@media (max-width: 600px) {
	.rv-hero__title { font-size: 32px; }
	.rv-hero__sub { font-size: 16px; }
	.rv-list-section { padding-bottom: var(--pw-space-2xl); }
	.rv-cta { padding: 0 0 var(--pw-space-2xl); }
	.rv-cta__box { padding: 40px var(--pw-space-lg); }
}
