/* DOB Starter Theme | css/10-a11y.css | v0.1.0 | 2026-04-30 | Generated by Claude, DOB-S2 */
/* Accessibility utilities: skip link, focus ring, reduced motion, visually-hidden. */

.skip-link {
	position: absolute;
	top: -100px;
	left: 0;
	background: var(--c-ink);
	color: var(--c-cream);
	padding: var(--s-3) var(--s-4);
	font-family: var(--f-label);
	font-size: var(--fs-label);
	text-decoration: none;
	z-index: 100;
	display: inline-flex;
	align-items: center;
	min-height: var(--tt-min);
}

.skip-link:focus {
	top: 0;
}

:focus-visible {
	outline: var(--focus-ring);
	outline-offset: var(--focus-offset);
	border-radius: 2px;
}

/* Honor reduced-motion preference */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		transition: none !important;
		animation: none !important;
		scroll-behavior: auto !important;
	}
}

/* Screen-reader only utility */
.visually-hidden,
.screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.visually-hidden:focus,
.screen-reader-text:focus {
	position: static !important;
	width: auto;
	height: auto;
	clip: auto;
	white-space: normal;
}
