/* Accessibility Toolbar */
.skip-to-main-content-link {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
	z-index: 999;
}

.skip-to-main-content-link:focus {
	position: fixed;
	top: 10px;
	left: 10px;
	width: auto;
	height: auto;
	padding: 10px 20px;
	background: #ffffff;
	color: #002f46;
	font-weight: 700;
	outline: 2px solid #ffffff;
	text-decoration: none;
	z-index: 999;
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Top nav inner: flex to push toolbar to the right */
header .navi-wrapper .nav-top-wrapper .nav-top-wrapper-inner {
	display: flex;
	align-items: center;
}

header .navi-wrapper .nav-top-wrapper .nav-top-wrapper-inner .nav-top {
	flex: 1;
}

/* Toolbar buttons */
.a11y-toolbar {
	display: flex;
	align-items: flex-end;
	gap: 2px;
	margin-left: 60px;
}

.a11y-toolbar button {
	background: none;
	border: none;
	color: #ffffff;
	cursor: pointer;
	padding: 0 6px;
	line-height: 1;
	border-radius: 6px;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	vertical-align: bottom;
}



.a11y-toolbar .a11y-contrast img {
	display: block;
	position: relative;
	top: 0;
}

.a11y-toolbar .a11y-fontsize {
	font-family: 'ClarityCity', sans-serif;
	font-weight: 700;
}

.a11y-toolbar .a11y-fontsize span[aria-hidden] {
	display: block;
	line-height: 0.7;
	margin-bottom: -0.05em;
}

.a11y-toolbar .a11y-fontsize[data-size="small"] span[aria-hidden] {
	font-size: 13px;
	position: relative;
	bottom: 1px;
}

.a11y-toolbar .a11y-fontsize[data-size="medium"] span[aria-hidden] {
	font-size: 21px;
}

.a11y-toolbar .a11y-fontsize[data-size="large"] span[aria-hidden] {
	font-size: 27px;
}

/* Desktop: show in top nav only */
@media (max-width: 1199.9px) {
	.a11y-toolbar:not(.a11y-toolbar-mobile) {
		display: none;
	}
}

/* Mobile: lang pills + a11y row */
.mobile-lang-a11y-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 13px 0 20px;
}

@media (min-width: 1200px) {
	.mobile-lang-a11y-row {
		display: none !important;
	}
}

@media (max-width: 1199.9px) {
	.mobile-lang-a11y-row {
		border-top: 1px solid #ffffff;
		padding-top: 13px;
		margin-left: -12px;
		margin-right: -12px;
		padding-left: 15px;
		padding-right: 15px;
	}
}

.lang-pills {
	display: flex;
	gap: 12px;
}

.lang-pill {
	color: #ffffff;
	text-decoration: none;
	font-size: 16px;
	font-family: 'ClarityCity', sans-serif;
	font-weight: 400;
	padding: 4px 8px;
	border: none;
	border-radius: 10px;
	background-color: #013a5a;
	transition: background-color 0.2s, color 0.2s;
}

.lang-pill:hover {
	background-color: #014a6e;
}

.lang-pill.active {
	background-color: #ffffff;
	color: #013a5a;
}

.a11y-toolbar.a11y-toolbar-mobile {
	margin-left: auto;
	justify-content: flex-end;
	padding: 0;
}

@media (min-width: 1200px) {
	.a11y-toolbar.a11y-toolbar-mobile {
		display: none;
	}
}

/* Tighten nav spacing when font is scaled */
@media (min-width: 1200px) {
	html.font-size-scaled header .navi-wrapper .nav-main-wrapper .nav-main-top-wrapper .navi .nav-main li {
		margin-left: 6px;
	}

	html.font-size-scaled header .navi-wrapper .nav-main-wrapper .nav-main-top-wrapper .navi .nav-main li > a {
		padding: 8px 6px;
	}
}

/* Welcome-info quicklinks: stack when font is scaled */
html.font-size-scaled .welcome-info .link-wrapper {
	flex-direction: column !important;
	height: auto !important;
}

html.font-size-scaled .welcome-info .link-wrapper span.separation {
	display: none !important;
}

/* High Contrast Mode — JS handles converting text colors and bg colors to grayscale.
 * No CSS filter used anywhere — images stay 100% untouched.
 * CSS overrides below handle hover/active states that JS can't catch.
 */

/* Tabs hover/active in contrast mode */
html.high-contrast .tabs .tab-navigation ul li a.active,
html.high-contrast .tabs .tab-navigation ul li a:hover {
	background-color: #333333 !important;
	color: #ffffff !important;
}

html.high-contrast .tabs .tab-navigation ul li a {
	color: #333333 !important;
	border-color: #333333 !important;
}

/* Dark bg sections — keep text white/readable */
html.high-contrast .text-box.bg-primary-color h2,
html.high-contrast .text-box.bg-primary-color p,
html.high-contrast .text-box.bg-primary-color a,
html.high-contrast .text-box.bg-primary-color span,
html.high-contrast .text-box.bg-primary-color li {
	color: #ffffff !important;
}

/* Submenu hover — no hover effect on contrast */
html.high-contrast header .navi-wrapper .nav-main-wrapper .nav-main-top-wrapper .navi .nav-main li > a:hover {
	background-color: transparent !important;
}
