/* ===========================================================
   RewardRace — FAQ v2
   Accordion list w/ purple left-bar on open state.
   =========================================================== */

.rrew-faq {
	--rrf-bg:        var(--rr-bg);
	--rrf-text:      var(--rr-heading);
	--rrf-body:      var(--rr-text);
	--rrf-soft:      var(--rr-muted);
	--rrf-border:    var(--rr-border);
	--rrf-pill-bg:   var(--rr-brand-tint);
	--rrf-toggle-bg: var(--rr-surface);
	--rrf-accent:    var(--rr-brand);

	background: var(--rrf-bg);
	color: var(--rrf-body);
	font-family: var(--rr-font-sans);
	box-sizing: border-box;
	padding: var(--rr-section-y) 0;
}
.rrew-faq *, .rrew-faq *::before, .rrew-faq *::after { box-sizing: border-box; }

.rrew-faq__inner {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 var(--rr-section-x);
}

/* ----- Heading ----- */
.rrew-faq__heading { margin: 0 0 var(--rr-space-12); }

.rrew-faq .rrew-faq__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: var(--rr-space-2);
	padding: 7px 16px 7px 12px;
	background: var(--rrf-pill-bg);
	border: 1px solid transparent;
	border-radius: var(--rr-radius-pill);
	font-size: var(--rr-fs-2xs);
	font-weight: 700;
	letter-spacing: var(--rr-tracking-wide);
	text-transform: uppercase;
	color: var(--rrf-accent);
	margin-bottom: var(--rr-space-5);
}

.rrew-faq__eyebrow-dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--rrf-accent);
	display: inline-block;
	animation: rrf-pulse 2s var(--rr-ease-out) infinite;
}
@keyframes rrf-pulse {
	0%, 100% { transform: scale(1); opacity: 1; }
	50%      { transform: scale(1.3); opacity: .7; }
}

.rrew-faq .rrew-faq__title {
	font-size: var(--rr-fs-h1);
	font-weight: 800;
	letter-spacing: var(--rr-tracking-tight);
	line-height: var(--rr-lh-tight);
	margin: 0;
	color: var(--rrf-text);
	text-wrap: balance;
}
.rrew-faq__title-lead { display: block; }
.rrew-faq__title-accent {
	display: block;
	color: var(--rrf-accent);
	font-weight: 800;
	margin-top: .05em;
}

/* ===========================================================
   Items — card-style accordion w/ purple bar on open
   =========================================================== */
.rrew-faq__list {
	display: flex;
	flex-direction: column;
	gap: var(--rr-space-3);
}

.rrew-faq-item {
	background: var(--rr-surface);
	border: 1px solid var(--rrf-border);
	border-radius: var(--rr-radius-lg);
	overflow: hidden;
	position: relative;
	transition: background-color var(--rr-dur-base) var(--rr-ease-out),
	            border-color var(--rr-dur-base) var(--rr-ease-out),
	            box-shadow var(--rr-dur-base) var(--rr-ease-out);
}
.rrew-faq-item::before {
	content: "";
	position: absolute;
	left: 0; top: 0; bottom: 0;
	width: 4px;
	background: var(--rrf-accent);
	opacity: 0;
	transition: opacity var(--rr-dur-base) var(--rr-ease-out);
}
.rrew-faq-item[open] {
	background: var(--rr-bg);
	border-color: var(--rrf-accent);
	box-shadow: var(--rr-shadow-md);
}
.rrew-faq-item[open]::before { opacity: 1; }

.rrew-faq-item__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--rr-space-6);
	padding: var(--rr-space-5) var(--rr-space-6);
	cursor: pointer;
	list-style: none;
	user-select: none;
	transition: color var(--rr-dur-fast) var(--rr-ease-out);
}
.rrew-faq-item__head::-webkit-details-marker { display: none; }
.rrew-faq-item__head::marker { display: none; content: ""; }

.rrew-faq-item__head:hover .rrew-faq-item__q { color: var(--rrf-accent); }

.rrew-faq-item__q {
	font-size: var(--rr-fs-h4);
	font-weight: 700;
	color: var(--rrf-text);
	letter-spacing: var(--rr-tracking-snug);
	line-height: var(--rr-lh-snug);
	flex: 1;
	min-width: 0;
	transition: color var(--rr-dur-fast) var(--rr-ease-out);
}

/* Toggle — gradient circle on hover/open */
.rrew-faq-item__toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--rrf-toggle-bg);
	border: 1px solid var(--rrf-border);
	color: var(--rrf-body);
	flex-shrink: 0;
	transition: background var(--rr-dur-base) var(--rr-ease-out),
	            color var(--rr-dur-base) var(--rr-ease-out),
	            border-color var(--rr-dur-base) var(--rr-ease-out),
	            transform var(--rr-dur-base) var(--rr-ease-out);
}
.rrew-faq-item:hover .rrew-faq-item__toggle {
	background: var(--rrf-accent);
	color: #FFFFFF;
	border-color: transparent;
}
.rrew-faq-item[open] .rrew-faq-item__toggle {
	background: var(--rr-brand-gradient);
	color: #FFFFFF;
	border-color: transparent;
	transform: rotate(180deg);
}

.rrew-faq-item__icon { display: block; }
.rrew-faq-item__icon--close { display: none; }
.rrew-faq-item[open] .rrew-faq-item__icon--plus  { display: none; }
.rrew-faq-item[open] .rrew-faq-item__icon--close { display: block; transform: rotate(-180deg); }

.rrew-faq-item__body {
	padding: 0 var(--rr-space-6) var(--rr-space-6) var(--rr-space-6);
	color: var(--rrf-soft);
	animation: rrew-faq-fade var(--rr-dur-base) var(--rr-ease-out);
}
@keyframes rrew-faq-fade {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}
.rrew-faq-item__body p {
	font-size: var(--rr-fs-md);
	line-height: var(--rr-lh-relaxed);
	color: var(--rrf-soft);
	margin: 0;
	max-width: 68ch;
}

@media (max-width: 880px) {
	.rrew-faq { padding: var(--rr-space-12) 0 var(--rr-section-y); }
	.rrew-faq__heading { margin-bottom: var(--rr-space-10); }
	.rrew-faq-item__head { padding: var(--rr-space-4) var(--rr-space-5); gap: var(--rr-space-4); }
	.rrew-faq-item__q { font-size: var(--rr-fs-md); }
	.rrew-faq-item__body { padding: 0 var(--rr-space-5) var(--rr-space-5); }
}

@media (max-width: 480px) {
	.rrew-faq__inner { padding: 0 var(--rr-space-4); }
	.rrew-faq-item__toggle { width: 36px; height: 36px; }
	.rrew-faq-item__q { font-size: var(--rr-fs-sm); }
	.rrew-faq-item__body p { font-size: var(--rr-fs-sm); }
}
