/**
 * SK Result Card - generisk komponent för AJAX-injicerade resultat-UIs.
 *
 * Återanvändbar pattern för alla SK-features som visar inline-result efter
 * användar-action (sjalvtest scoring, shop add-to-cart-confirmation,
 * GF-confirmations, kurs-completion, quiz-results m.fl.).
 *
 * Namespace: .skr-result-* (SK Result, generisk - inte modul-specifik)
 * Tokens: bridge-tokens från SK design-system v2 (per CLAUDE.md
 *         "bridge-tokens-regel" - speglas tills sk-design-tokens.css är live)
 *
 * Användning:
 *   <div class="skr-result" data-sk-scroll-on-mount tabindex="-1">
 *     <div class="skr-result__hero">🎯 Ditt resultat</div>
 *     <div class="skr-result__score skr-result__score--pulse">...</div>
 *     ...
 *   </div>
 *
 * @since 2026-05-12 (refaktor från sk-sjalvtest-scoring inline-CSS)
 */

/* === Bridge-tokens (speglar SK design-system v2-prototypen) === */
.skr-result {
	--skr-primary: #0d9488;
	--skr-primary-hover: #0f766e;
	--skr-primary-soft: #ccfbf1;
	--skr-warn: #dc2626;
	--skr-warn-soft: #fef2f2;
	--skr-warn-amber: #f59e0b;
	--skr-warn-amber-soft: #fffbeb;
	--skr-warn-amber-text: #78350f;
	--skr-text: #1a202c;
	--skr-muted: #4a5568;
	--skr-bg-soft: #f8fafc;
	--skr-border: #e2e8f0;
	--skr-radius-sm: 6px;
	--skr-radius-md: 8px;
	--skr-radius-lg: 10px;
	--skr-radius-xl: 12px;
	--skr-shadow-pulse: 0 0 0 0 rgba(13, 148, 136, 0.45);
	--skr-scroll-offset: 90px;

	margin: 24px 0;
	font-size: 1rem;
	line-height: 1.6;
	color: var(--skr-text);
	scroll-margin-top: var(--skr-scroll-offset);
}

.skr-result:focus {
	outline: none;
}

/* === Hero-band (visuell anchor överst) === */
.skr-result__hero {
	margin: 0 0 16px;
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--skr-primary) 0%, var(--skr-primary-hover) 100%);
	color: #fff;
	border-radius: var(--skr-radius-lg);
	text-align: center;
	font-size: 1.15em;
	font-weight: 600;
	letter-spacing: 0.01em;
	animation: skrHeroIn 0.5s ease-out;
}

.skr-result__hero-icon {
	display: inline-block;
	margin-right: 6px;
	font-size: 1.15em;
	vertical-align: -2px;
}

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

/* === Crisis-banner (för YMYL Tier 1 suicid-screening) === */
.skr-result__crisis {
	margin: 0 0 24px;
	padding: 20px 24px;
	background: var(--skr-warn-soft);
	border-left: 5px solid var(--skr-warn);
	border-radius: var(--skr-radius-md);
}

.skr-result__crisis h2 {
	margin: 0 0 10px;
	color: var(--skr-warn);
	font-size: 1.25em;
}

.skr-result__crisis p {
	margin: 0 0 10px;
}

.skr-result__crisis a {
	color: var(--skr-warn);
	font-weight: 600;
	text-decoration: underline;
}

.skr-result__crisis ul {
	margin: 8px 0;
	padding-left: 20px;
}

/* === Score-card (huvudnummer) === */
.skr-result__score {
	margin: 0 0 16px;
	padding: 28px 24px;
	background: var(--skr-bg-soft);
	border-radius: var(--skr-radius-xl);
	text-align: center;
	box-shadow: var(--skr-shadow-pulse);
}

.skr-result__score--pulse {
	animation: skrScorePulse 1.8s ease-out;
}

@keyframes skrScorePulse {
	0% {
		box-shadow: 0 0 0 0 rgba(13, 148, 136, 0.45);
		background: var(--skr-primary-soft);
	}
	60% {
		box-shadow: 0 0 0 14px rgba(13, 148, 136, 0);
		background: var(--skr-bg-soft);
	}
	100% {
		box-shadow: 0 0 0 0 rgba(13, 148, 136, 0);
		background: var(--skr-bg-soft);
	}
}

.skr-result__score-number {
	font-size: 3.5em;
	font-weight: 700;
	color: var(--skr-primary);
	line-height: 1;
	margin: 0;
}

.skr-result__score-max {
	font-size: 1em;
	color: var(--skr-muted);
	margin: 4px 0 0;
}

/* === Severity-block (label + body-text) === */
.skr-result__severity {
	margin: 0 0 20px;
	padding: 18px 20px;
	background: #fff;
	border: 1px solid var(--skr-border);
	border-left: 4px solid var(--skr-primary);
	border-radius: var(--skr-radius-lg);
}

.skr-result__severity-label {
	margin: 0 0 8px;
	font-size: 1.2em;
	font-weight: 600;
	color: var(--skr-primary);
}

.skr-result__severity-body {
	margin: 0;
	color: var(--skr-text);
}

.skr-result__severity-body p {
	margin: 0 0 10px;
}

.skr-result__severity-body p:last-child {
	margin-bottom: 0;
}

/* === Disclaimer (medicinsk varning, mjuk amber) === */
.skr-result__disclaimer {
	margin: 20px 0;
	padding: 14px 18px;
	background: var(--skr-warn-amber-soft);
	border-left: 4px solid var(--skr-warn-amber);
	border-radius: var(--skr-radius-sm);
	font-size: 0.92em;
	color: var(--skr-warn-amber-text);
}

/* === Källa (citation) === */
.skr-result__source {
	margin: 16px 0 0;
	font-size: 0.85em;
	color: var(--skr-muted);
	font-style: italic;
}

/* === Action-knappar === */
.skr-result__actions {
	margin: 24px 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.skr-result__action {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px; /* WCAG 2.1 AA touch-target */
	padding: 10px 18px;
	border-radius: var(--skr-radius-md);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95em;
	line-height: 1.2;
	transition: background 0.15s, color 0.15s;
}

.skr-result__action--primary {
	background: var(--skr-primary);
	color: #fff;
}

.skr-result__action--primary:hover,
.skr-result__action--primary:focus-visible {
	background: var(--skr-primary-hover);
	color: #fff;
}

.skr-result__action--secondary {
	background: #fff;
	color: var(--skr-primary);
	border: 1px solid var(--skr-primary);
}

.skr-result__action--secondary:hover,
.skr-result__action--secondary:focus-visible {
	background: var(--skr-primary-soft);
	color: var(--skr-primary);
}

/* === Tillgänglighet: prefers-reduced-motion === */
@media (prefers-reduced-motion: reduce) {
	.skr-result__hero,
	.skr-result__score--pulse {
		animation: none;
	}
}
