/* ============================================================
 * SC Core — Module FAQ dynamique (SEO / GEO)
 * Accordéon accessible, mutualisé pour SC Avis / SC Bonus /
 * SC Taux de Défaut. Hérite des tokens de sc-core.css
 * (dépendance 'sc-core-css').
 * ============================================================ */

.sc-faq {
	font-family: var(--sc-font-body);
	margin: 34px 0 22px;
}

.sc-faq-title {
	font-family: var(--sc-font-head);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.25;
	color: var(--sc-ink);
	margin: 0 0 18px;
	letter-spacing: .01em;
}

.sc-faq-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* ---------- Carte question ---------- */
.sc-faq-item {
	background: var(--sc-card);
	border: 1px solid var(--sc-line);
	border-radius: var(--sc-radius-sm);
	overflow: hidden;
	transition: border-color .18s ease, box-shadow .18s ease;
}
.sc-faq-item:hover {
	border-color: var(--sc-line-2);
}
.sc-faq-item.is-open {
	border-color: var(--sc-accent);
	box-shadow: 0 6px 22px rgba(124, 141, 240, 0.10);
}

/* ---------- En-tête / bouton ---------- */
.sc-faq-h {
	margin: 0;
	font-size: inherit;
	font-weight: inherit;
}
.sc-faq-q {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	text-align: left;
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 16px 18px;
	font-family: var(--sc-font-body);
	font-size: 15.5px;
	font-weight: 600;
	line-height: 1.4;
	color: var(--sc-ink);
	transition: color .15s ease;
}
.sc-faq-q:hover { color: var(--sc-accent); }
.sc-faq-q:focus-visible {
	outline: 2px solid var(--sc-accent);
	outline-offset: -2px;
	border-radius: var(--sc-radius-sm);
}
.sc-faq-q-txt { flex: 1; }

/* ---------- Chevron ---------- */
.sc-faq-ico {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	position: relative;
	border-radius: 50%;
	background: var(--sc-accent-bg);
	transition: transform .22s ease, background .15s ease;
}
.sc-faq-ico::before,
.sc-faq-ico::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 9px;
	height: 2px;
	border-radius: 2px;
	background: var(--sc-accent);
	transform: translate(-50%, -50%);
	transition: transform .22s ease, opacity .22s ease;
}
.sc-faq-ico::after { transform: translate(-50%, -50%) rotate(90deg); }
.sc-faq-item.is-open .sc-faq-ico { background: linear-gradient(100deg, var(--sc-accent), var(--sc-accent-2)); }
.sc-faq-item.is-open .sc-faq-ico::before,
.sc-faq-item.is-open .sc-faq-ico::after { background: #0e1525; }
.sc-faq-item.is-open .sc-faq-ico::after { transform: translate(-50%, -50%) rotate(0deg); opacity: 0; }

/* ---------- Réponse ---------- */
.sc-faq-a {
	color: var(--sc-ink-2);
}
.sc-faq-a[hidden] { display: none; }
.sc-faq-a-inner {
	padding: 2px 18px 18px;
	font-size: 14.5px;
	line-height: 1.62;
}
.sc-faq-a-inner > :first-child { margin-top: 0; }
.sc-faq-a-inner > :last-child { margin-bottom: 0; }
.sc-faq-a-inner p { margin: 0 0 10px; }
.sc-faq-a-inner a {
	color: var(--sc-accent);
	text-decoration: underline;
	text-underline-offset: 2px;
	text-decoration-thickness: 1px;
}
.sc-faq-a-inner a:hover { color: var(--sc-accent-2); }
.sc-faq-a-inner strong { color: var(--sc-ink); font-weight: 700; }
.sc-faq-a-inner ul,
.sc-faq-a-inner ol { margin: 8px 0 10px; padding-left: 20px; }
.sc-faq-a-inner li { margin: 3px 0; }

/* ---------- Animation d'ouverture (légère) ---------- */
@media (prefers-reduced-motion: no-preference) {
	.sc-faq-item.is-open .sc-faq-a-inner {
		animation: sc-faq-reveal .24s ease;
	}
	@keyframes sc-faq-reveal {
		from { opacity: 0; transform: translateY(-4px); }
		to   { opacity: 1; transform: none; }
	}
}

/* ---------- Mobile ---------- */
@media (max-width: 600px) {
	.sc-faq-title { font-size: 19px; }
	.sc-faq-q { padding: 14px 14px; font-size: 14.5px; }
	.sc-faq-a-inner { padding: 2px 14px 16px; font-size: 14px; }
}
