/* =====================================================================
   Reviews — polished funnel UI for /leave-a-review/ + [pep_reviews_form]

   Uses the same theme tokens as the rest of the polished system:
   --ui-surface, --ui-ink, --ui-border, --ui-radius, --ui-primary,
   --ui-primary-soft. The page is centered, generous, and progressive
   — only the active step is visible.
===================================================================== */

.pep-reviews {
	max-width: 640px;
	margin: 3rem auto;
	padding: 0 1rem;
	color: var( --ui-ink );
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.pep-reviews--compact {
	margin: 1rem auto;
	max-width: 560px;
}

.pep-reviews__step {
	display: none;
	animation: pep-reviews-fadein 0.35s ease;
}

.pep-reviews__step.is-active {
	display: block;
}

@keyframes pep-reviews-fadein {
	from { opacity: 0; transform: translateY( 8px ); }
	to   { opacity: 1; transform: translateY( 0 ); }
}

.pep-reviews__head {
	text-align: center;
	margin-bottom: 1.5rem;
}

.pep-reviews__headline {
	font-size: 1.65rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var( --ui-ink );
	margin: 0 0 0.5rem;
	line-height: 1.2;
}

.pep-reviews__subhead {
	color: var( --ui-ink-soft );
	font-size: 1rem;
	line-height: 1.5;
	margin: 0;
}

.pep-reviews__card {
	background: var( --ui-surface );
	border: 1px solid var( --ui-border );
	border-radius: var( --ui-radius );
	padding: 2rem 1.75rem;
	box-shadow: var( --ui-shadow );
	text-align: center;
}

.pep-reviews__card--celebrate {
	padding: 2.5rem 1.75rem;
}

.pep-reviews__icon-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: linear-gradient( 135deg, var( --ui-primary ) 0%, var( --bs-primary-dark, #d14d16 ) 100% );
	color: #fff;
	margin: 0 auto 1.5rem;
	box-shadow: 0 8px 24px rgba( 242, 99, 34, 0.35 );
}

.pep-reviews__icon-wrap--soft {
	background: linear-gradient( 135deg, var( --ui-success ) 0%, #15803d 100% );
	box-shadow: 0 8px 24px rgba( 22, 163, 74, 0.3 );
}

.pep-reviews__question {
	font-size: 1.05rem;
	font-weight: 600;
	color: var( --ui-ink );
	margin: 0 0 1.5rem;
}

/* --- Star rating --- */

.pep-reviews__stars {
	display: flex;
	gap: 0.4rem;
	justify-content: center;
	margin: 0 0 1rem;
}

.pep-reviews__star {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 0;
	padding: 0.5rem;
	cursor: pointer;
	color: #d1d5db;
	transition: transform 0.12s ease, color 0.15s ease;
}

.pep-reviews__star svg {
	width: 48px;
	height: 48px;
	display: block;
}

.pep-reviews__star:hover { transform: scale( 1.08 ); }
.pep-reviews__star:active { transform: scale( 0.95 ); }

.pep-reviews__star.is-hover,
.pep-reviews__star.is-selected {
	color: #fbbf24;
}

.pep-reviews__star.is-selected svg {
	fill: #fbbf24;
}

.pep-reviews__star:focus-visible {
	outline: 2px solid var( --ui-primary );
	outline-offset: 4px;
	border-radius: 6px;
}

.pep-reviews__rating-label {
	min-height: 1.5rem;
	color: var( --ui-primary );
	font-weight: 700;
	font-size: 1.05rem;
	margin: 0;
	letter-spacing: 0.01em;
}

/* --- CTAs --- */

.pep-reviews__cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	padding: 0.95rem 2rem;
	font-size: 1rem;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	border-radius: var( --ui-radius-sm );
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	margin: 1rem auto 0;
	transition: opacity 0.15s ease, transform 0.05s ease, box-shadow 0.15s ease;
	width: 100%;
	max-width: 360px;
}

/* Inside the low-rating feedback form, CTAs fill the form width and
   sit stacked with a centered "or" divider between them. */
.pep-reviews__form .pep-reviews__cta {
	max-width: none;
	width: 100%;
}

/* Scoped + ! to win against any content-area anchor color rules
   (theme styles like `.entry-content a { color: orange }` would
   otherwise inherit into the <span> and make the text disappear
   against our orange gradient background). */
.pep-reviews .pep-reviews__cta--primary,
.pep-reviews .pep-reviews__cta--primary:visited,
.pep-reviews .pep-reviews__cta--primary span,
.pep-reviews .pep-reviews__cta--primary svg {
	color: #fff !important;
}

.pep-reviews__cta--primary {
	background: linear-gradient( 135deg, var( --ui-primary ) 0%, var( --bs-primary-dark, #d14d16 ) 100% );
	box-shadow: 0 4px 14px rgba( 242, 99, 34, 0.32 );
}

.pep-reviews .pep-reviews__cta--primary:hover,
.pep-reviews .pep-reviews__cta--primary:focus-visible {
	opacity: 0.95;
	transform: translateY( -1px );
	box-shadow: 0 6px 20px rgba( 242, 99, 34, 0.4 );
}

.pep-reviews__cta--ghost {
	color: var( --ui-ink );
	background: var( --ui-surface );
	border: 2px solid var( --ui-border );
}

.pep-reviews__cta--ghost:hover,
.pep-reviews__cta--ghost:focus-visible {
	border-color: var( --ui-primary );
	color: var( --ui-primary );
	transform: translateY( -1px );
}

.pep-reviews__skip {
	display: inline-block;
	margin-top: 1rem;
	background: transparent;
	border: 0;
	color: var( --ui-ink-soft );
	font-size: 0.9rem;
	cursor: pointer;
	text-decoration: underline;
	text-decoration-color: var( --ui-border-strong );
	text-underline-offset: 3px;
}

.pep-reviews__skip:hover { color: var( --ui-ink ); }

.pep-reviews__or {
	text-align: center;
	margin: 1rem 0 0.5rem;
	color: var( --ui-ink-faint );
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

/* --- Low-rating form --- */

.pep-reviews__low-head {
	text-align: center;
	margin-bottom: 1.5rem;
}

.pep-reviews__form {
	text-align: left;
}

.pep-reviews__field {
	margin-bottom: 1.25rem;
}

.pep-reviews__label {
	display: block;
	font-weight: 600;
	color: var( --ui-ink );
	margin-bottom: 0.5rem;
	font-size: 0.95rem;
}

.pep-reviews__required {
	color: var( --ui-danger );
	margin-left: 0.25rem;
}

.pep-reviews__form input[type="text"],
.pep-reviews__form input[type="tel"],
.pep-reviews__form textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: 0.95rem;
	color: var( --ui-ink );
	background: var( --ui-surface );
	border: 1px solid var( --ui-border );
	border-radius: var( --ui-radius-sm );
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-shadow: none;
	font-family: inherit;
}

.pep-reviews__form input[type="text"]:focus,
.pep-reviews__form input[type="tel"]:focus,
.pep-reviews__form textarea:focus {
	outline: none;
	border-color: var( --ui-primary );
	box-shadow: 0 0 0 3px rgba( var( --bs-primary-rgb, 242, 99, 34 ), 0.15 );
}

.pep-reviews__form textarea {
	min-height: 100px;
	resize: vertical;
}

.pep-reviews__yesno,
.pep-reviews__choices {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.pep-reviews__choices {
	flex-direction: column;
}

.pep-reviews__choice {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 1.1rem;
	background: var( --ui-surface );
	border: 1.5px solid var( --ui-border );
	border-radius: 999px;
	font-size: 0.92rem;
	cursor: pointer;
	transition: all 0.15s ease;
	user-select: none;
}

.pep-reviews__choices .pep-reviews__choice {
	border-radius: var( --ui-radius-sm );
}

.pep-reviews__choice:hover {
	border-color: var( --ui-primary );
	color: var( --ui-primary );
}

.pep-reviews__choice input {
	margin: 0;
	accent-color: var( --ui-primary );
}

.pep-reviews__choice input:checked ~ span {
	font-weight: 700;
}

.pep-reviews__choice:has( input:checked ) {
	background: var( --ui-primary-soft );
	border-color: var( --ui-primary );
	color: var( --ui-primary );
}

.pep-reviews__consent {
	color: var( --ui-ink-faint );
	font-size: 0.78rem;
	line-height: 1.5;
	margin: 1rem 0 0.5rem;
	text-align: center;
}

.pep-reviews-disabled {
	max-width: 560px;
	margin: 3rem auto;
}

@media (max-width: 576px) {
	.pep-reviews { margin: 1.5rem auto; }
	.pep-reviews__card { padding: 1.5rem 1.15rem; }
	.pep-reviews__headline { font-size: 1.35rem; }
	.pep-reviews__star svg { width: 40px; height: 40px; }
	.pep-reviews__stars { gap: 0.2rem; }
	.pep-reviews__cta { padding: 0.85rem 1.5rem; font-size: 0.92rem; }
}
