@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  src: url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-regular.woff2') format('woff2'),
		url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-regular.woff') format('woff');
}
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 700;
  src: url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-700.woff2') format('woff2'),
		url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-700.woff') format('woff');
}
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 900;
  src: url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-900.woff2') format('woff2'),
		url('../lib/fonts/source-sans-pro-v14-latin/source-sans-pro-v14-latin-900.woff') format('woff');
}
@font-face {
  font-family: 'Merriweather';
  font-style: normal;
  font-weight: 400;
  src: url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-regular.woff2') format('woff2'),
		url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-regular.woff') format('woff');
}
@font-face {
  font-family: 'Merriweather';
  font-style: normal;
  font-weight: 700;
  src: url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-700.woff2') format('woff2'),
		url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-700.woff') format('woff');
}
@font-face {
  font-family: 'Merriweather';
  font-style: normal;
  font-weight: 900;
  src: url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-900.woff2') format('woff2'),
		url('../lib/fonts/merriweather-v23-latin/merriweather-v23-latin-900.woff') format('woff');
}



/* Global styles */
html, body { padding: 0; margin: 0; font: normal 16px/1.5 "Source Sans Pro", "Trebuchet MS", Tahoma, sans-serif; box-sizing: border-box; 
	-webkit-text-size-adjust: 100%; color: #222;
	height: 100%; width: 100%;
}
*, *::before, *::after { font-family: inherit; font-size: inherit; line-height: inherit; box-sizing: inherit; color: inherit; }

/* Basic element styles */
h1, h2, h3, h4, h5, h6 { margin: 0; line-height: 1.2; font-weight: 900; }
h1 { font-size: 28px; }
h2 { font-size: 24px; }
h3 { font-size: 20px; }
h4 { font-size: 16px; }
h5 { font-size: 16px; color: #666; }
h6 { font-size: 16px; color: #666; font-style: italic; }
img { max-width: 100%; height: auto; }
video { display: block; max-width: 100%; height: auto; margin: 0 auto; }
table { border-collapse: collapse; }
form { display: block; margin: 0; padding: 0; }
fieldset { border: 1px solid #888; padding: 12px; margin: 1em 0; }
legend { font-weight: bold; }
#app legend + * { margin-top: 0; }
hr { border: 0; border-bottom: 1px solid #ccc; background: transparent; height: 1px; margin: 1em 0; width: 100%; }

/* Margins for content elements */
h1, h2, h3, h4, h5, h6 { margin-top: 2rem; margin-bottom: 1rem; }
p, ul, ol { margin-top: 1rem; margin-bottom: 1rem; }
h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child,
p:first-child, ul:first-child, ol:first-child { margin-top: 0; }
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, h6:last-child,
p:last-child, ul:last-child, ol:last-child { margin-bottom: 0; }
li > ul, li > ol { margin-top: 0; margin-bottom: 0; }
b, strong { font-weight: 900; }

/* Custom font for content headings */
.main h1, .main h2, .main h3, .main h4, .main h5, .main h6 { font-family: "Merriweather"; }

/* Links */
a { color: #4E6EB1; }
a:hover { color: #64acff; }
a:focus { color: #4E6EB1; }
a:active { color: #194E84; }

/* Anchor offset to account for static header */
a[id][name]:empty { display: block; position: relative; top: -100px; visibility: hidden; }

/* Text and links on inverted dark backgrounds */
.txt-i, .txt-i a { color: #fff; }
.txt-i a:hover { background: rgba(255,255,255,.25); }
.txt-i a:active { background: rgba(255,255,255,.5); }

/* Text color and links */
.txt-red, .txt-red a { color: #a00; }
.txt-red a:hover { color: #800; }
.txt-red a:active { color: #400; }
.txt-green, .txt-green a { color: #0a0; }
.txt-green a:hover { color: #080; }
.txt-green a:active { color: #040; }
.txt-bg-yellow { background: #ff0; padding: 4px; margin: -4px; }
.txt-bg-red { background-color: #a00; color: #fff; }
.txt-bg-green { background-color: #0a0; color: #fff; }

/* Old site content - should be deleted */
.newsite-hide { display: none !important; }

/* Focus */
input, textarea, select, button, a { position: relative; }
input:focus, textarea:focus, select:focus, button:focus, a:focus { outline: 4px solid #64acff; z-index: 1; outline-offset: 0; }

/* Form, input elements */
input, textarea, select, button, .btn, .btns a { color: #222; display: inline-block; -webkit-appearance: none; -moz-appearance: none; appearance: none; border-radius: 0; border: 1px solid #222; padding: 6px; background: #fff; outline-offset: 0; }
input, select, button, .btn, .btns a { height: calc(1.5em + 14px); /* 38px; */ }
input::placeholder { color: #888; }
input:disabled, textarea:disabled, select:disabled, button:disabled { cursor: not-allowed; background-color: #eee; }
textarea { resize: vertical; }
#app .select2-selection--single,
select { background-repeat: no-repeat; background-position: right 6px center; background-size: 9px; padding-right: 21px; 
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16px' height='14px' viewBox='0 0 16 14'%3E%3Cpolygon fill='%23000' points='16,0 8,13.855 0,0 '/%3E%3C/svg%3E");
}
select[multiple] { height: auto; padding: 0; background: #fff; }
select[multiple] option { padding-left: 6px; }
option { display: block; }
select:-moz-focusring { color: transparent; text-shadow: 0 0 0 #000; }
button::-moz-focus-inner { border:0; }
select::-ms-expand { display: none; }
/* -- Radio buttons and checkboxes require an adjacent label element! */
input[type=radio],
input[type=checkbox] { position: absolute; left: -999em; }
/* -- line height 20px is height minus border, makes input line up nicely with text baseline */
input[type=radio] + label::before, 
input[type=checkbox] + label::before { display: inline-block; content: "\00a0"; line-height: 20px; width: 22px; height: 22px; background: #fff; border: 2px solid #444; position: relative; margin-right: 6px; 
	background-position: center; background-repeat: no-repeat;
}
input[type=checkbox] + label::before { background-size: 14px; }
input[type=radio] + label::before { border-radius: 999px; }
input[type=radio]:checked + label::before {  
	background-image: radial-gradient(#222, #222 50%, #fff 55%);
}
input[type=checkbox]:checked + label::before { background-color: #444;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16px' height='13px' viewBox='0 0 16 13'%3E%3Cpolygon fill='%23FFF' points='6.274,12.549 0,6.274 2.823,3.451 6.274,6.902 13.176,0 16,2.823 '/%3E%3C/svg%3E");
}
input[type=radio]:focus + label::before,
input[type=checkbox]:focus + label::before { box-shadow: 0 0 0 4px #64acff; z-index: 1; }
input[type=radio]:disabled + label::before,
input[type=checkbox]:disabled + label::before { cursor: not-allowed; background-color: #ddd; border-color: #888; }

/* for invisible grouping elements */
fieldset.grp { border: none; margin: 0; padding: 0; }

/* Buttons, links styled as buttons */
button, a.btn, .btn, .btns a { background: #194E84; color: #fff; border-radius: 4px; text-decoration: none; padding: 7px 12px; border: none; height: auto; }
button:hover, .btn:hover, .btns a:hover { background: #12375D; }
button:active, .btn:active, .btns a:active { background: #0D2741; }
button:focus, .btn:focus, .btns a:focus { background: #12375D; outline: none; box-shadow: 0 0 0 4px #64acff; }

/* Input wrapper */
.field { display: block; margin: 1em 0; }
.field input, .field textarea, .field select { width: 100%; display: block; }
.field:first-child { margin-top: 0; }
.field:last-child { margin-bottom: 0; }
.field.opt-inline > div > div { display: inline; margin-right: 12px; }

/* Required indicators <b class="req">*</b> */
.req { color: #a00; }
.field label > b.req { margin-left: 6px; }

/* Form error messages, notices */
.errors { border-left: 4px solid #a00; background: #fee; color: #a00; padding: 6px 12px; margin: 1em 0; }
.notice { border-left: 4px solid #0a0; background: #efe; color: #0a0; padding: 6px 12px; margin: 1em 0; }

/* textarea heights. Default show 2.5 lines of text. Height = 2.5 * font height * line height + padding + border height */
textarea, textarea.r2 { height: calc(2.5 * 1em * 1.5 + 7px) }
textarea.r3 { height: calc(3.5 * 1em * 1.5 + 7px) }
textarea.r4 { height: calc(4.5 * 1em * 1.5 + 7px) }
textarea.r5 { height: calc(5.5 * 1em * 1.5 + 7px) }

/* Widths based on input type */
input.int { width: 60px; }
input.date { width: 120px; }
input.time { width: 120px; }

/* Alt button-link styles */
a.btn-red { background: #841919; color: #fff; }
a.btn-red:hover, a.btn-red:focus { background: #5D1212; color: #fff; }
a.btn-red:active { background: #410D0D; color: #fff; }
a.btn-green { background: #228418; color: #fff; color: #fff; }
a.btn-green:hover, a.btn-green:focus { background: #155D12; color: #fff; }
a.btn-green:active { background: #0D410D; color: #fff; }

/* Fix for rows of buttons that wrap in user content */
.btn, .btns a { margin-bottom: 3px; }



/* Button as a link */
button.a { border: none; background: transparent; padding: 0; margin: 0; color: #4E6EB1; height: auto; display: inline; cursor: pointer; border-radius: 0; text-decoration: underline; text-align: left; }
button.a:hover { color: #64acff; }
button.a:focus { color: #4E6EB1; box-shadow: none; outline: 4px solid #64acff; }
button.a:active { color: #1C3E88; }

/* Delete button as link in forms */
button.a.delete { color: #a00; }
button.a.delete:hover { color: #800; }
button.a.delete:active { color: #400; }

/* jQuery UI tweaks */
.ui-widget { font-family: inherit; font-size: inherit; }
.ui-widget-content { color: inherit; }

/* Fix for rows of buttons that wrap in user content */
#main .btn { margin-bottom: 2px; }

/* Image Utilities */
.img-circle { clip-path: circle(50% at center); border-radius: 999px; }
.imgright, img.right { float: right; margin: 0 0 6px 6px; clear: right; }
.imgleft, img.left { float: left; margin: 0 6px 6px 0; clear: left; }
.img-right-50, .img-right-25 { float: right; max-width: 50% !important; margin: 0 0 8px 8px; clear: right; }
.img-right-25 { max-width: 25% !important; }
.img-left-50, .img-left-25 { float: left; max-width: 50% !important; margin: 0 8px 8px 0; clear: left; }
.img-left-25 { max-width: 25% !important; }

/* For content wider than the page */
.scrollx { overflow-x: auto; width: calc(100% + 24px); margin: 0 -12px; padding: 0 12px; }



/* Image preloading */
body:after { position: absolute; width: 0; height: 0; overflow: hidden; z-index: -1;
	content: url(../lib/busy-bg.gif) url(../lib/busy-bg-i.gif) /* url(img2.png) ... */;
}

/* Loading */
.busy-bg { background-image: url(../lib/busy-bg.gif) !important; }
.busy-bg-i { background-image: url(../lib/busy-bg-i.gif) !important; }

/* Layout */
body { overflow-y: scroll; overflow-x: hidden; background: #fff; }
#wrap { display: flex; min-height: 100vh; flex-direction: column; min-height: 100vh; }
#body, #nav { flex: 1 0 auto; }
/* This flex has an issue with the carousel (something with margin). remove not-is-front when resolved */
body:not(.is-front):not(.nav-open) #body { display: flex; flex-direction: column; }
#cols { display: flex; align-items: stretch; max-width: 1024px; width: 100%; padding: 0 12px; margin: 0 auto; flex: 1 0 auto; }
#main { flex: 1; }

#skip { position: fixed; top: -50px; left: 0; padding: 0 12px; display: flex; align-items: center; height: 50px; background: #222; color: #fff; z-index: 1000; font-weight: 900; text-decoration: none; text-transform: uppercase; outline-offset: -5px; }
#skip:focus { top: 0; }

/* Left + main columns */
#side, #main { padding: 36px 0; }
@media not all and (min-width: 700px) {
	#side { display: none; }
	#main { width: 100%; }
}
@media (min-width: 700px) {
	#side { width: calc(194px + 12px); flex: 0 0 auto; border-right: 1px solid #ccc; background: #f8f8f8; margin-left: -12px; }
	#side + #main { padding-left: 24px; width: calc(100% - (194px + 12px)); }
}
/* TO DO: BETTER WAY TO HANDLE MARGIN */
#main > :first-child { margin-top: 0; }
#main > :last-child { margin-bottom: 0; }
#main > .float:first-child + * { margin-top: 0; }

/* Head */
#head { color: #fff; display: flex; align-items: stretch; width: 100%; max-width: 1024px; margin: 0 auto; height: 50px; fill: #fff; border-color: #000; }
#head a, #head svg { color: inherit; fill: inherit; }
#head-wrap { position: sticky; top: 0; z-index: 100; }
.head-bg::before { background: #222; content: ''; z-index: -1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
body:not(.nav-open).transi-head #head-wrap::before { transition: opacity .3s; }
body:not(.nav-open).has-hero.seethru-head #head-wrap::before { opacity: 0; }

/* Duplicate head bg for transparent head transition */
#head-bg { position: sticky; top: 0; width: 100%; z-index: 1; }
#head-bg::before { height: 50px; background-position: center;  background-size: cover; background-repeat: no-repeat; }

/* Logo & title */
#logo { display: flex; padding: 12px 12px; outline-offset: -5px; text-decoration: none; align-items: stretch; }
#logo > svg { margin: 0; padding: 0; height: 26px; width: 27.95px; flex: 0 0 auto; margin-right: 12px; }
#logo > h1 { font-weight: 900; margin: 0; padding: 0; text-transform: uppercase; display: flex; flex-direction: column; justify-content: space-between; line-height: 1; margin: 0; white-space: nowrap; font-size: 16px; }
@media not all and (min-width: 390px) {
	#logo-mc { display: flex; flex-direction: column; justify-content: space-between; flex: 1; }
	#logo-mo { margin-top: -3px; }
	#logo-ex { display: none; }
}
@media (min-width: 390px) {
	#logo-mc { margin-top: -3px; }
	#logo-ex { font-size: 10px; margin-bottom: -2px; }
}

/* Nav buttons */
#nav-btns { display: flex; margin-left: auto; font-weight: 900; line-height: 1; align-items: stretch; }
#nav-btns a { text-decoration: none; display: flex; flex-direction: column; justify-content: space-between; align-items: center; text-transform: uppercase; outline-offset: -5px; position: relative; }
#nav-btns a::before { -webkit-font-smoothing: antialiased; font-family: "Font Awesome 5 Free"; font-weight: 900; width: 1em; text-align: center; }
#nav-search::before { content: "\f002"; }
#nav-menu::before { content: "\f0c9"; }
#nav-lang::before { content: "\f57d"; }
.nav-short { display: none; }
@media (max-width: 700px) {
	.nav-long { display: none; }
	.nav-short { display: inline; }
}
@media not all and (min-width: 550px) {
	/* #nav-btns { flex-direction: row-reverse; } */
	#nav-btns a { height: 50px; width: 50px; padding: 12px 0; }
	#nav-btns a::before { font-size: 16px; margin-top: -1px; }
	#nav-btns a > span { font-size: 10px; margin-bottom: -2px; }
}
@media (min-width: 550px) {
	#nav-btns a { flex-direction: row; padding: 0 12px; }
	#nav-btns a::before { margin-right: 6px; }
	a#nav-menu::before { text-align: left; }
	a#nav-search::before { text-align: right; }
	a#nav-search::before { margin: 0 0 0 6px; }
	a#nav-search { flex-direction: row-reverse; }
}
@media (hover) and (min-width: 550px) {
	#nav-btns a::after { content: ''; width: calc(100% - 24px); position: absolute; right: 12px; bottom: 1px; border-bottom: 4px solid #fff; border-color: inherit; display: none; opacity: 1; }
	#nav-btns a:hover::after { display: block; } 
	.nav-open #nav-btns a:not(.nav-active):hover { background: #333; color: #fff; }
}

/* Nav toggle */
/* mf = menu full, mm = mobile menu */
#nav, #menu, #search, #lang { display: none; }
.nav-open #nav, .nav-menu #menu, .nav-search #search, .nav-lang #lang { display: block; }
#nav-btns a[aria-expanded=true]::before { content: "\f00d"; color: #d00; }
.nav-open #body, 
.nav-open #skip,
.nav-open #site-alert,
.nav-open #totop { display: none; }
#nav { color: #fff; width: 100%; max-width: 1024px; position: relative; margin: 0 auto; }
#nav::before { content: ''; background: #222; position: absolute; top: 0; left: calc(50% - 50vw); width: 100vw; height: 100%; z-index: -1; }
#mf { display: none; }
@media (min-width: 700px) {
	#mf { display: block; }
	#mm { display: none; }
}
.nav-open #head-wrap::before { background: #fff !important; /* Override menu colors */ }
.nav-open #logo { color: #000; fill: #000; }
.nav-open #nav-btns a:not(.nav-active) { color: #000; }
.nav-open #nav-btns a.nav-active { background: #222; color: #fff; }
.nav-open .slide-bg { display: none; }

/* Search bar */
#search-form { display: block; margin: 0; position: relative; padding: 12px; padding-bottom: 0px; }
#search-q { width: 100%; padding: 6px; padding-right: 36px; }
#search-submit { position: absolute; top: 13px; right: 13px; border: none; height: 36px; width: 36px; text-align: center; padding: 6px 0; background: transparent; color: #222; z-index: 5; border-radius: 0; }
#search-submit:focus, #search-submit:hover { background-color: #64acff; box-shadow: none; outline: none; color: #fff; }

/* Search autocomplete - override jquery */
#app ul.search-ul { position: static !important; width: auto !important; display: block !important; background: transparent; border: none; }
#app ul.search-ul, #app ul.search-ul li { margin: 0; padding: 0; list-style: none; border: none; }
#app ul.search-ul li a, #app ul.search-ul li span { margin: 0; display: block; text-decoration: none; color: #fff; padding: 6px 12px; border: 1px solid rgba(255,255,255,.2); border-width: 0 0 1px 0; }
#app ul.search-ul li span { color: #888; }
#app ul.search-ul .ui-state-active { background: #64acff; color: #fff; }
@media (min-width: 1024px) {
	#app ul.search-ul { padding-left: 12px; padding-right: 12px; }
	#search-q { padding-left: 12px; }
}


/* Lang menu */
@media (min-width: 700px) {
	#ml { padding: 12px 0; }
	#ml ul, #ml ul li { list-style: none; margin: 0; padding: 0; }
	#ml ul { column-count: 4; column-gap: 0; margin: 0; }
	#ml ul a { display: block; break-inside: avoid; padding: 6px 12px; outline-offset: -4px; color: #fff; text-decoration: none; }
	#ml ul a:hover { background-color: #fff; color: #194E84; }
}
@media not all and (min-width: 700px) {
	#ml ul, #ml li { list-style: none; margin: 0; padding: 0; }
	#ml ul { display: flex; flex-wrap: wrap; }
	#ml li { width: 50%; display: block; }
	#ml a { display: block; padding: 6px 12px; color: #fff; border: 1px solid rgba(255,255,255,.2); border-width: 0 0 1px 0; position: relative; font-weight: normal; text-decoration: none; }
	#ml a:nth-child(odd) { border-right-width: 1px; }
	@media (hover) { #ml a:hover { background: #64acff; color: #fff; } }
	#ml a:focus { outline-offset: -4px; }
	#ml a:active { background: #fff; color: #000; }
}

/* Full menu, language menu */
#mf { padding: 12px 0; }
#mf .ul-cols, #mf .ul-cols li { list-style: none; margin: 0; padding: 0; }
#mf .ul-cols { column-count: 4; column-gap: 0; margin: 0; }
#mf .ul-cols a { display: block; break-inside: avoid; padding: 6px 12px; outline-offset: -4px; color: #fff; text-decoration: none; }
#mf .ul-cols a:hover { background-color: #fff; color: #194E84; }
	
/* Mobile menu */
#mm { padding: 12px 0; }
#mm ul { display: none; }
#mm ul.mnav-open { display: block; }
#mm ul, #mm li { list-style: none; margin: 0; padding: 0; }
#mm a, #mm li > strong { display: block; padding: 6px 44px; color: #fff; border: 1px solid rgba(255,255,255,.2); border-width: 0 0 1px 0; position: relative; font-weight: normal; text-decoration: none; }
#mm li > strong { color: #888; }
@media (hover) { #mm a:hover { background: #64acff; color: #fff; } }
#mm a:focus { outline-offset: -4px; }
#mm a:active { background: #fff; color: #000; }

/* Mobile menu icons */
#mm .nav-home::before,
#mm .nav-down::before,
#mm .nav-back::before,
#mm .nav-next::before,
#mm [data-link=out]::before { 
	font-family: "Font Awesome 5 Free"; font-weight: 900; text-align: center; position: absolute; top: 6px; width: 20px; left: 12px; 
}	
#mm .nav-home::before { content: "\f015"; }
#mm .nav-down::before { content: "\f078"; }
#mm .nav-back::before { content: "\f060"; }
#mm .nav-next::before { content: "\f061"; right: 12px; left: auto; }
#mm [data-link=out]::before { content: "\f35d"; right: 12px; left: auto; }
#mm [data-link-ext]::before,
#mm .nav-new::before { font-size: 12px; text-transform: uppercase; padding: 1px 2px; font-family: inherit; font-weight: normal; content: attr(data-link-ext); background: #fff; color: #000; border-radius: 4px; 
	position: absolute; top: 8px; right: 22px; transform: translateX(50%);
}
#mm .nav-new::before { content: "new"; background: #0a0; color: #fff; }

/* Footer */
#foot { color: #ccc; position: relative; font-size: 14px; padding: 24px 12px calc(62px + 80px + 12px) 12px; background: #222 url(city-silouette.png) bottom center / auto 140px no-repeat; 
	 max-width: 1024px; width: 100%; margin: 0 auto; 
}
#foot::before { content: ''; position: absolute; z-index: -1; width: 100vw; left: calc(50% - 50vw); background: #222; top: 0; height: 100%; }
#foot a { color: #ccc; text-decoration: none; }
#foot a:hover, #foot a:focus, #foot a:active { color:#fff; }
#foot-seal { display: block; margin: 0 auto; }
#foot-seal img { display: block; border: 4px solid transparent; margin: -4px; }
#foot-seal:focus { outline: none; }
#foot-seal:focus img { border-color: #64ACFF; }
#foot-links, #foot-links li { list-style: none; padding: 0; margin: 0; }
#foot-links li { display: inline-block; white-space: nowrap; }
#foot-bye { margin-top: 12px; }
#foot-social, #foot-social li { list-style: none; padding: 0; margin: 0; }
#foot-social { margin-top: 12px; }
#foot-social li { padding: 0 6px; display: inline-block; white-space: nowrap; }
#foot-social li i { margin-right: 6px; }

@media not all and (min-width: 700px) {
	#foot-seal { width: 100%; max-width: 194px; }
	#foot-links li { padding: 0 6px; }
	#foot-text { text-align: center; margin-top: 12px; }
}
@media (min-width: 700px) {
	#foot { display: flex; background-position: bottom right; background-size: 45%; padding-bottom: 24px; }
	#foot-seal { width: 194px; flex: 0 0 auto; }
	#foot-text { flex: 1; overflow: hidden; padding: 4px; margin: -4px; margin-left: calc(24px - 4px); /* hide leftmost pipe */}
	#foot-links { margin-left: -24px; }
	#foot-links li::before { content: '|'; color: #666; width: 24px; display: inline-block; text-align: center; }
	#foot-social { margin-left: -6px; }
}
@media (min-width: 900px) {
	#foot { background-size: 55%; }
}

/* Side navigation */
#side { font-size: 14px; line-height: 1.2; }
#side ul, #side li { list-style: none; display: block; padding: 0; margin: 0; }
#side a, #side li > strong { padding: 6px 12px; color: #222; display: block; text-decoration: none; position: relative; }	
#side li > strong { color: #888; }
body.side-stick #side-stick { position: sticky; top: 50px; }
#snav a.nav-home,
#snav li > strong,
#snav a.nav-down, 
#snav a.nav-strong, 
#snav a.nav-back { background: #eee; font-weight: bold; padding-top: 5px; border: 1px solid #ccc; border-width: 1px 0 0 0; font-weight: bold; }
#snav a.nav-home,
#snav li > strong,
#snav a.nav-down,
#snav a[data-link=out],
#snav a[data-link-ext],
#snav a.nav-new,
#snav a.nav-next { padding-right: calc(6px + 16px + 6px); }
#snav a.nav-back	{ padding-left: calc(12px + 16px + 6px); }
#snav a.nav-home::before,
#snav li > strong::before,
#snav a.nav-down::before,
#snav a.nav-back::before,
#snav a.nav-next::before,
#snav a[data-link=out]::before { font-family: "Font Awesome 5 Free"; font-weight: 900; text-align: center; position: absolute; top: 6px; width: 16px; opacity: .5; right: 6px; }
#snav a.nav-home::before { content: "\f015"; }
#snav li > strong::before,
#snav a.nav-down::before { content: "\f078"; }
#snav a.nav-back::before { content: "\f060"; left: 12px; right: auto; }
#snav a.nav-next::before { content: "\f061"; }
#snav a[data-link=out]::before { content: "\f35d"; font-size: 10px; top: 8px; opacity: .3; }
#snav a[data-link-ext]::before,
#snav a.nav-new::before { font-size: 9px; text-transform: uppercase; padding: 1px 2px; opacity: .25; font-family: inherit; font-weight: normal; content: attr(data-link-ext); background: #222; color: #fff; border-radius: 4px; 
	position: absolute; top: 8px; right: 14px; transform: translateX(50%);
}
#snav a.nav-new::before { content: "new"; background: #0a0; opacity: 1; }
#snav a[data-link=here] { background: #afd4ff; border: 1px solid #64acff; border-width: 1px 0; padding-top: 5px; padding-bottom: 5px; }
#snav a[data-link=here]::after { position: absolute; content: ''; background: url(chevron-right.svg); height: 100%; width: 12px; right: -12px; top: 0;  background-size: 12px 100%; }
#snav a:hover { color: #64acff; }
@media (min-width: 1024px) {
	#side { background: linear-gradient(to right, #fff 50%, #f8f8f8 100%); }
	#snav a.nav-home,
	#snav li > strong,
	#snav a.nav-down,
	#snav a.nav-strong,
	#snav a.nav-back { background: linear-gradient(90deg, #fff, #eee); border-image: linear-gradient(90deg, #fff, #ccc) 1; font-weight: bold; }
	#snav a[data-link=here] { background: linear-gradient(90deg, #fff, #afd4ff); border-image: linear-gradient(90deg, #fff, #64acff) 1; }
	#snav a:hover { color: #64acff; /* background: linear-gradient(90deg, #fff, #afd4ff); */ }	
}
@media (min-width: 1080px) {
	#snav a.nav-home,
	#snav li > strong,
	#snav a.nav-down,
	#snav a.nav-back { padding-left: calc(12px + 16px + 12px); margin-left: calc(-12px - 16px - 12px + 12px); padding-right: 12px; }
	#snav a.nav-home::before,
	#snav li > strong::before,
	#snav a.nav-down::before { left: 12px; right: auto; }
}

/* Back to top link */
#totop { 
	position: fixed; bottom: 80px; right: -63px; background: #222; color: #fff; text-decoration: none; transition: right .2s;
	text-transform: uppercase; height: 64px; width: 63px; display: flex; flex-direction: column; justify-content: space-between; align-items: center; line-height: 1; outline-offset: -4px; padding: 12px 0;	
	border: 1px solid #fff; border-width: 1px 0 1px 1px;
}
body.show-totop #totop, #totop:focus { right: 0; }
#totop span { margin-bottom: -2px; font-size: 16px; font-weight: bold; }
#totop::before { -webkit-font-smoothing: antialiased; display: block; font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f062"; font-size: 26px; margin-top: -1px; }
@media (hover) { 
	#totop:hover { background: #64acff; border-color: #64acff; }
}
#totop:active { background: #4E6EB1; border-color: #4E6EB1; }
@media not all and (min-width: 700px) {
	#totop { width: 51px; height: 52px; right: -51px; }
	#totop::before { font-size: 16px; margin-top: -1px; }
	#totop span { font-size: 10px; margin-bottom: -2px; }
}

/* File browser */
.has-js .mc-custom-files ul button[aria-expanded=false] + ul { display: none; }
.has-js .mc-custom-files ul button .fa::before { content: "\f65e"; }
.has-js .mc-custom-files ul button[aria-expanded=true] .fa::before { content: "\f07c"; }





/* Hero images */
.hero { height: 400px; color: #fff;  background-color: #444; background-position: center;  background-size: cover; background-repeat: no-repeat; margin-top: -50px; position: relative; z-index: 20; }
.hero::before { content: ''; width: 100%; height: 100%; position: absolute; left: 0; top: 0; display: block;
	background-image: linear-gradient(rgba(0,0,0,.5), rgba(0,0,0,0));
}
/* Default hero overlay is .5 to 0 gradient. Can be made darker/lighter with: */
.hero-bg-8-2::before { background-image: linear-gradient(rgba(0,0,0,.8), rgba(0,0,0,.2)); }
.hero-bg-8-4::before { background-image: linear-gradient(rgba(0,0,0,.8), rgba(0,0,0,.4)); }
.hero-bg-9-4::before { background-image: linear-gradient(rgba(0,0,0,.9), rgba(0,0,0,.4)); }
.hero-bg-8::before { background: rgba(0,0,0,.8); }
.hero-bg-i-4::before { background: rgba(255,255,255,.4); }
.hero-bg-none::before { background-image: none; }

/* Container for hero content */
.hero > div { padding: 50px 12px 0 12px; width: 100%; max-width: 1024px; margin: 0 auto; height: 100%; }
.hero-txt { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; z-index: 1; position: relative; }
.hero-txt h1 { font-size: 32px; margin: 0; }

/* Shadows to contrast hero */
body:not(.no-head-shadow) .hero-txt h1,
body:not(.no-head-shadow):not(.nav-open).has-hero.seethru-head #head { text-shadow: 0 4px 8px rgb(0,0,0,.5); }
body:not(.no-head-shadow) .hero-txt img,
body:not(.no-head-shadow):not(.nav-open).has-hero.seethru-head #head svg { filter: drop-shadow(0px 4px 8px rgba(0,0,0,.5)); }
body:not(.no-head-shadow) .hero-txt .btns a:not(:focus) { box-shadow: 0 4px 8px rgb(0,0,0,.5); }

/* Hero buttons */
.hero-txt .btns a { background: #fff; color: #000; }
.hero-txt .btns a:hover { background: rgba(255,255,255,.8); }
.hero-txt .btns a:active { background: rgba(0,0,0,.7); color: #fff; }
.hero-txt .btns a .fa, .hero-txt .btns a .fab { margin-right: 6px; }

/* Nav buttons */
#nav .btns a { background: #444; color: #fff; }
#nav .btns a:hover { background: #666; }
#nav .btns a:active { background: #fff; color: #000; }
#nav .btns { padding: 12px 12px 0 12px; text-align: center; margin-bottom: -3px; }
@media not all and (min-width: 700px) {
	#nav .btns { padding-bottom: 9px; margin-bottom: 0; border-bottom: 1px solid rgba(255,255,255,.2); }
}

/* Red hero button */
.hero-txt .btns a.btn-red { background: #a00; color: #fff; }
.hero-txt .btns a.btn-red:hover { background: #400; }
.hero-txt .btns a.btn-red:active { background: #800; }

/* Individual hero images */
#hero-visitor { background-image: url(/image/app/hero/visitor!p=1&q=30.jpg); }
#hero-resident { background-image: url(/image/app/hero/resident2!p=1&q=30.jpg); }
#hero-business { background-image: url(/image/app/hero/business!p=1&q=30.jpg); }
#hero-government { background-image: url(/image/app/hero/cob1!p=1&q=30.jpg); }

#hero-elections { background-image: url(/image/app/hero/elections!p=1&q=30.jpg); }
#hero-elections-registration { background-image: url(/image/app/hero/elections-registration!p=1&q=30.jpg); }

#hero-clerk { background-image: url(/image/app/hero/cob4!p=1&q=30.jpg); background-position: center bottom; }
#hero-clerk-sportinglicenses { background-image: url(/image/app/hero/clerk-sporting!p=1&q=30.jpg); background-position: right bottom; }
#hero-clerk-passports { background-image: url(/app/hero/fabric-overlay.png), linear-gradient(-45deg, #131F3C, #3c528f); background-size: auto; background-repeat: repeat; }
#hero-dmv { background-image: url(/image/app/hero/dmv-misc!p=1&q=30.jpg); }
#hero-dmv-contact { background-image: url(/image/app/hero/dmv!p=1&q=30.jpg); }

#hero-executive { background-image: url(/image/app/hero/city13b!p=1&q=30.jpg); background-position: center bottom; }
#hero-communications { background-image: url(/image/app/hero/cob2!p=1&q=30.jpg); }

#hero-da { background-image: url(/image/app/hero/da2!p=1&q=30.jpg); background-position: left center; }

#hero-dei { background-image: url(/image/app/hero/dei!p=1&q=30.jpg); background-size: auto 100%; background-repeat: repeat-x; }

#hero-des { background-image: url(/image/app/hero/shore3a!p=1&q=30.jpg); background-position: center 80%; }
#hero-des-fleet { background-image: url(/image/app/hero/des-fleet!p=1&q=30.jpg); background-position: center bottom; }
#hero-des-purewaters { background-image: url(/image/app/hero/lake3c!p=1&q=30.jpg); background-position: center bottom; }
#hero-des-climate-committee { background-image: url(/image/app/hero/lake1b!p=1&q=30.jpg); background-position: center bottom; }
#hero-des-stormwaterquality { background-image: url(/image/app/hero/water1!p=1&q=30.jpg); }
#hero-des-stormwater-coalition { background-image: url(/image/app/hero/water3!p=1&q=30.jpg); background-position: center bottom; }
#hero-des-sewercollections { background-image: url(/image/app/hero/des-misc!p=1&q=30.jpg); }
#hero-des-environmentalrecycling { background-image: url(/image/app/hero/des-misc5!p=1&q=30.jpg); }
#hero-des-residentialrecycling { background-color: #51ade0; background-image: url(/image/app/hero/des-bins2!p=1&q=30.jpg); background-size: auto 100%; background-repeat: no-repeat; }
#hero-des-recyclingprograms { background-image: url(/image/app/hero/des-trailer!p=1&q=30.jpg); }

#hero-ecopark { background: url(/image/app/hero/ecopark-grid13!p=1&q=80.jpg) center / auto 100% repeat, linear-gradient(#14562E, #70C185); }

#hero-irobay { background-image: url(/image/app/hero/irobay1b!p=1&q=30.jpg); }
#hero-irobay-recreation { background-image: url(/image/app/hero/irobay-boats1b!p=1&q=30.jpg); }
#hero-irobay-living { background-image: url(/image/app/hero/irobay-bridge1b!p=1&q=30.jpg); background-position: center bottom; }
#hero-irobay-water { background-image: url(/image/app/hero/irobay-water2!p=1&q=30.jpg); }
#hero-irobay-fishing { background-image: url(/image/app/hero/irobay-boats2c!p=1&q=30.jpg); background-position: center bottom; }

#hero-des-solidwaste { background-image: url(/image/app/hero/des-misc2!p=1&q=30.jpg); }
#hero-des-wastewater { background-image: url(/image/app/hero/des-vanlare!p=1&q=30.jpg); }
#hero-des-businessrecycling { background-image: url(/image/app/hero/des-misc3!p=1&q=30.jpg); }
#hero-des-environmentallab { background-image: url(/image/app/hero/des-vanlare2!p=1&q=30.jpg); }
#hero-des-millseat { background-image: url(/image/app/hero/des-millseat!p=1&q=30.jpg); }
#hero-des-recyclingcenter { background-image: url(/image/app/hero/des-recyclingcenter!p=1&q=30.jpg); }
#hero-des-newsletter { background-image: url(/image/app/hero/des-city-green!p=1&q=30.jpg); }

#hero-des-alexa { background: url(hero/safety-dots.png) center /  8px 8px, radial-gradient(#385335, #000); }

#hero-gis { background-image: url(/image/app/hero/gis!p=1&q=30.jpg); }
#hero-gis-mapgallery { background-image: url(/image/app/hero/gis-layers!p=1&q=30.jpg); }
#hero-gis-gps { background-image: url(/image/app/hero/gis-gps2!p=1&q=30.jpg); }
#hero-gis-records { background-color: #888; background-image: url(/image/app/hero/gis-records!p=1&q=30.jpg); }
#hero-gis-data { background-image: url(/image/app/hero/gis-data!p=1&q=30.jpg); }

#hero-finance { background: url(hero/finance-budget2.png) center / auto 100% repeat-x, linear-gradient(-30deg, #213b67, #10260c); }
#hero-finance-budget { background: url(hero/finance-budget2.png) center / auto 100% repeat-x, linear-gradient(-30deg, #3CB9E3, #0E192C); }
#hero-purch { background-image: url(/image/app/hero/purch2!p=1&q=30.jpg); background-position: left top; }
#hero-purch-doingbusiness { background-image: url(/image/app/hero/purch1!p=1&q=30.jpg); background-position: 80% center; }
#hero-property { background-image: url(/image/app/hero/property1a!p=1&q=30.jpg); background-position: center bottom; }
#hero-property-assessorcontacts { background-image: url(/image/app/hero/resident2!p=1&q=30.jpg); background-position: center bottom; }

#hero-historian { background-image: url(/image/app/hero/historian!p=1&q=30.jpg); background-position: center bottom; }

#hero-hr { height: 446px; background: url(hero/hr.jpg) top center no-repeat; margin-top: 0; padding-top: 0; border-bottom: 1px solid #ccc; }
#hero-hr-guides { background-image: url(/image/app/hero/hr-guides!p=1&q=30.jpg); }
#hero-hr-careers { background: #898196 url(hero/hr-careers.jpg) center / auto 100% repeat-x; }
#hero-hr-civilservice { background-image: url(/image/app/hero/hr-civilservice!p=1&q=30.jpg); background-position: center bottom; }
#hero-hr-makeadifference { background-image: url(/image/app/hero/makeadifference!p=1&q=30.jpg); background-position: 56% center; }
#hero-hr-makeadifference::before { background-image: linear-gradient(rgba(0,58,110,1), rgba(0,58,110,0)); }

/* #hero-hs { background-image: url(/image/app/hero/colors1a!p=1&q=30.jpg); } */
#hero-hs { background-image: url(/image/app/hero/colors-people1b!p=1&q=30.jpg); }
/*            #hero-hs { background-image: url(/image/app/hero/color-people!p=1&q=30.jpg); background-size: auto 100%; background-repeat: repeat; }*/
/*#hero-hs-family { background-image: url(/image/app/hero/colors1b!p=1&q=30.jpg); }*/
#hero-hs-family { background-image: url(/image/app/hero/colors-people4b!p=1&q=30.jpg); }
/*             #hero-hs-family { background-image: url(/image/app/hero/colors-kids!p=1&q=30.jpg); }*/
/*#hero-hs-preventative { background-image: url(/image/app/hero/colors2b!p=1&q=30.jpg); }*/
#hero-hs-preventative { background-image: url(/image/app/hero/colors-people3b!p=1&q=30.jpg); }
/*#hero-hs-child { background-image: url(/image/app/hero/colors2a!p=1&q=30.jpg); }*/
#hero-hs-child { background-image: url(/image/app/hero/colors-people2b!p=1&q=30.jpg); }
/*#hero-hs-adult { background-image: url(/image/app/hero/colors3b!p=1&q=30.jpg); }*/
#hero-hs-adult { background-image: url(/image/app/hero/colors-people8b!p=1&q=30.jpg); }


#hero-hs-adoption { background-image: url(/image/app/hero/colors-people5b!p=1&q=30.jpg); }
#hero-hs-daycare { background-image: url(/image/app/hero/colors-people7b!p=1&q=30.jpg); }

#hero-hs-fostercare { background-image: url(/image/app/hero/colors-people10b!p=1&q=30.jpg); }

#hero-hs-employmentprograms { background-image: url(/image/app/hero/colors-people9b!p=1&q=30.jpg); }
#hero-hs-lettersupport { background-image: url(/image/app/hero/colors-people6b!p=1&q=30.jpg); }


/*6b - random people
9b - random people */


#hero-cii { background-image: url(/image/app/hero/city-night2b!p=1&q=30.jpg); background-position: center bottom; }

#hero-mh { background-image: url(/image/app/hero/clouds3!p=1&q=50.jpg); background-position: right bottom; }
#hero-mh-services { background-image: url(/image/app/hero/clouds6b!p=1&q=50.jpg); background-position: center bottom; }
#hero-mh-csboard { background-image: url(/image/app/hero/clouds8!p=1&q=50.jpg); background-position: center bottom; }
#hero-mh-helpful-links { background-image: url(/image/app/hero/clouds7b!p=1&q=50.jpg); background-position: center bottom; }
#hero-mh-faq { background-image: url(/image/app/hero/clouds10a!p=1&q=50.jpg); background-position: left bottom; }




#hero-youth { background-image: url(/image/app/hero/youth2!p=1&q=30.jpg); }
#hero-aging { background-image: url(/image/app/hero/aging1b!p=1&q=30.jpg); }
#hero-opioid { background-image: url(/image/app/hero/concrete-plant2!p=1&q=30.jpg); background-position: 75% center; }

#hero-opioid-resources { background-image: url(/image/app/hero/as!p=1&q=30.jpg); }
#hero-opioid-info { background-image: url(/image/app/hero/arrow-blue-bg!p=1&q=30.jpg); background-position: left center; }

#hero-is { background-image: url(/image/app/hero/is!p=1&q=30.jpg); }

#hero-law { background-image: url(/image/app/hero/law1a!p=1&q=30.jpg); }

#hero-legislature { background-image: url(/image/app/hero/city5!p=1&q=30.jpg); background-position: center bottom; }
#hero-legislature-legislators { background-image: url(/image/app/hero/city-aerial1b!p=1&q=30.jpg); background-position: center; }

#hero-libra { background-image: url(/image/app/hero/libra!p=1&q=30.jpg); }

#hero-mcc { background-image: url(/image/app/hero/mcc!p=1&q=30.jpg); }

#hero-mch { background-image: url(/image/app/hero/mch1!p=1&q=30.jpg); }

#hero-parks { background-image: url(/image/app/hero/parks-webster1b!p=1&q=30.jpg); background-position: center top; }
#hero-parks-bayeast { background-image: url(/image/app/hero/parks-bayeast5!p=1&q=30.jpg); }
#hero-parks-blackcreek { background-image: url(/image/app/hero/parks-blackcreek12!p=1&q=30.jpg); background-position: 80% center; }
#hero-parks-beikirch { background-image: url(/image/app/hero/parks-beikirch1!p=1&q=30.jpg); }
#hero-parks-churchville { background-image: url(/image/app/hero/parks-churchville2!p=1&q=30.jpg); }
#hero-parks-devilscove { background-image: url(/image/app/hero/parks-devilscove!p=1&q=30.jpg); }
#hero-parks-dogparks { background-image: url(/image/app/hero/parks-dogparks!p=1&q=30.jpg); }
#hero-parks-durandeastman { background-image: url(/image/app/hero/parks-durandeastman14!p=1&q=30.jpg); }
#hero-parks-ellison { background-image: url(/image/app/hero/parks-ellison3!p=1&q=30.jpg); }
#hero-parks-geneseevalley { background-image: url(/image/app/hero/parks-geneseevalley5!p=1&q=30.jpg); }
#hero-parks-greececanal { background-image: url(/image/app/hero/parks-greececanal4!p=1&q=30.jpg); background-position: 30% bottom; }
#hero-parks-highland { background-image: url(/image/app/hero/parks-highland!p=1&q=30.jpg); background-position: center top; }
#hero-parks-baywest { background-image: url(/image/app/hero/parks-baywest8!p=1&q=30.jpg); }
#hero-parks-lehighvalley { background-image: url(/image/app/hero/parks-lehighvalley6!p=1&q=30.jpg); }
#hero-parks-wetlands { background-image: url(/image/app/hero/parks-wetlands!p=1&q=30.jpg); }
#hero-parks-mendonponds { background-image: url(/image/app/hero/parks-mendonponds12!p=1&q=30.jpg); background-position: right bottom; }
#hero-parks-northampton { background-image: url(/image/app/hero/parks-northampton8!p=1&q=30.jpg); }
#hero-parks-oatka { background-image: url(/image/app/hero/parks-oatka10!p=1&q=30.jpg); background-position: 80% bottom; }
#hero-parks-ontariobeach { background-image: url(/image/app/hero/parks-ontariobeach16a!p=1&q=50.jpg); background-position: center bottom; }
#hero-parks-powdermill { background-image: url(/image/app/hero/parks-powdermill3!p=1&q=30.jpg); background-position: 60% center; }
#hero-parks-seneca { background-image: url(/image/app/hero/parks-seneca12!p=1&q=30.jpg); background-position: right bottom; }
#hero-parks-zoo { background-image: url(/image/app/hero/parks-zoo7!p=1&q=30.jpg); background-position: right center; }
#hero-parks-tryon { background-image: url(/image/app/hero/parks-tryon1!p=1&q=30.jpg); }
#hero-parks-webster { background-image: url(/image/app/hero/parks-webster2!p=1&q=30.jpg); background-position: 30% bottom; }
#hero-parks-golf { background-image: url(/image/app/hero/parks-golf!p=1&q=30.jpg); background-position: left bottom; }
#hero-parks-forms { background-image: url(/image/app/hero/parks-ontariobeach3!p=1&q=30.jpg); }
#hero-parks-rent-field { background-image: url(/image/app/hero/parks-greececanal2!p=1&q=30.jpg); background-position: right bottom; }
#hero-parks-camping { background-image: url(/image/app/hero/parks-misc1!p=1&q=30.jpg); }
#hero-parks-trailmaps { background-image: url(/image/app/hero/parks-mendonponds5!p=1&q=30.jpg); }
#hero-parks-rules { background-image: url(/image/app/hero/parks-oatka3!p=1&q=30.jpg); }
#hero-parks-conservation { background-image: url(/image/app/hero/parks-durandeastman11!p=1&q=30.jpg); }
#hero-parks-pickuptheparks { background-image: url(/image/app/hero/parks-ellison8!p=1&q=30.jpg); }
#hero-parks-conservatory { background-image: url(/image/app/hero/parks-highland-conservatory1!p=1&q=30.jpg); }
#hero-parks-lifeguards { background-image: url(/image/app/hero/parks-ontariobeach8b!p=1&q=30.jpg); background-position: 70% bottom; }

#hero-parks-movies { background: url(/app/hero/white-stars-1100x400.png?v2) center / auto 100% repeat-x, radial-gradient(#13466D, #081825); }
#hero-parks-winterfest { background: url(/app/hero/white-stars-1100x400.png?v2) center / auto 100% repeat-x, radial-gradient(#354a6c, #2a3a55); }
/* #hero-parks-lilac { background-image: url(/image/app/hero/parks-highland-flowers14!p=1&q=30.jpg); } */
#hero-parks-lilac { background-image: url(/image/app/hero/parks-highland-flowers18!p=1&q=30.jpg); }

#hero-planning { background-image: url(/image/app/hero/city10c!p=1&q=30.jpg); }
#hero-planning-planning { background: #24487e url(hero/planning-planning1.png) center / auto 600px repeat-x; }
#hero-planning-planning > div::before { background: none; }
#hero-planning-workforce { background-image: url(/image/app/hero/planning-workforce2!p=1&q=30.jpg); }
#hero-planning-farmland { background-image: url(/image/app/hero/planning-planning!p=1&q=30.jpg); background-position: right center; }
#hero-planning-fab { background-image: url(/image/app/hero/parks-powdermill8!p=1&q=30.jpg); }
#hero-planning-community { background-image: url(/image/app/hero/cobb1!p=1&q=30.jpg); background-position: center bottom; }
#hero-planning-irobay { background-image: url(/image/app/hero/irobay-boats2c!p=1&q=30.jpg); background-position: center bottom; }
#hero-planning-retain { background-image: url(/image/app/hero/home12a!p=1&q=30.jpg); }
#hero-economic { background-image: url(/image/app/hero/city2a!p=1&q=30.jpg); background-position: center 75%; }
#hero-planforward { background-image: url(/image/app/hero/planforward!p=1&q=30.jpg); }


#hero-defender { background-image: url(/image/app/hero/defender2!p=1&q=30.jpg); }

#hero-health { background-image: url(/image/app/hero/colors-blue!p=1&q=30.jpg); }
#hero-health-contact { background-image: url(/image/app/hero/health2!p=1&q=30.jpg); }
#hero-health-commissioner { background-image: url(/image/app/hero/health1!p=1&q=30.jpg); }
#hero-health-nursing-immunization { background-image: url(/image/app/hero/health-nursing-immunization!p=1&q=30.jpg); }
#hero-health-health-data { background-image: url(/image/app/hero/health-health-data!p=1&q=30.jpg); }
#hero-health-vitalrecords { background-image: url(/image/app/hero/health-vitalrecords!p=1&q=30.jpg); }
#hero-health-prepare-personal-preparedness { background-image: url(/image/app/hero/health-prepare2!p=1&q=30.jpg); }
#hero-health-covid19-vaccine { background-image: url(/image/app/hero/health-shot!p=1&q=30.jpg); }
#hero-health-prepare { background-image: url(/image/app/hero/health-prepare6!p=1&q=30.jpg); }
/* #hero-health-maternal-foster-care { background-image: url(/image/app/hero/starlight!p=1&q=30.jpg); } */ 
#hero-health-maternal-foster-care { background-image: url(/image/app/hero/starlight2!p=1&q=30.jpg); }
/* #hero-health-impact { background-color: #6D469D; background-image: url(hero/as-impact5-overlay.png), url(hero/as-impact5.gif); background-repeat: no-repeat, repeat; background-size: 100% 100%, auto 100%; } */
#hero-health-impact { background: #121640 url(/app/hero/blue-diagonal-lines-bg2.gif) repeat; }

#hero-addiction { background-image: url(/image/app/hero/colors-purple4!p=1&q=30.jpg); }

#hero-hdchild { background-image: url(/image/app/hero/health-children!p=1&q=30.jpg); }

#hero-eh { background-image: url(/image/app/hero/river1!p=1&q=30.jpg); }
#hero-eh-watershed { background-image: url(/image/app/hero/wetland2!p=1&q=30.jpg); background-position: center bottom; }
#hero-eh-child { background-image: url(/image/app/hero/parks-powdermill10!p=1&q=30.jpg); }
#hero-eh-citizenaction { background-image: url(/image/app/hero/lake-flowers!p=1&q=30.jpg); }
#hero-eh-emc { background-image: url(/image/app/hero/shore1a!p=1&q=30.jpg); background-position: left 80%; }
#hero-eh-environmentalquality { background-image: url(/image/app/hero/shore2a!p=1&q=30.jpg); background-position: center 80%; }
#hero-eh-food { background-image: url(/image/app/hero/eh-food!p=1&q=30.jpg); background-position: center bottom; }
#hero-eh-publicwater { background-image: url(/image/app/hero/eh-publicwater!p=1&q=30.jpg); background-position: 80% center; }
#hero-eh-poolsbeaches { background-image: url(/image/app/hero/parks-ontariobeach11c!p=1&q=30.jpg); background-position: center bottom; }
#hero-eh-housingrodentcontrol { background-image: url(/image/app/hero/resident2!p=1&q=30.jpg); background-position: center bottom; }

#hero-publicintegrity { background: url(hero/opi-dots.png) center /  8px 8px, linear-gradient(to bottom right, #313e49 15%, #5C666E, #313e49 85%); }

#hero-safety { background-image: url(/image/app/hero/city-night!p=1&q=30.jpg); }
#hero-safety-ecd { background-image: url(/image/app/hero/safety-ecd!p=1&q=30.jpg); }
#hero-safety-police { background-image: url(/image/app/hero/safety-police!p=1&q=30.jpg); }
#hero-safety-crimelab { background-image: url(/image/app/hero/safety-crimelab!p=1&q=30.jpg); }
#hero-safety-weights { background-image: url(/image/app/hero/safety-weights!p=1&q=30.jpg); }
#hero-ts { background-image: url(/image/app/hero/traffic-misc1!p=1&q=30.jpg); }
#hero-ts-trafficsafety { background-image: url(/image/app/hero/safety-trafficsafety!p=1&q=30.jpg); }
#hero-ts-stopdwi { background-image: url(/image/app/hero/safety-stopdwi!p=1&q=30.jpg); }

#hero-ts-drive2bbetter { background-image: url(/image/app/hero/driving!p=1&q=30.jpg); }
#hero-school-bus-safety { background-image: url(/image/app/hero/school-bus2!p=1&q=30.jpg); background-position: center bottom; }

#hero-safety-oem { background-image: url(/image/app/hero/city1a!p=1&q=30.jpg); }
#hero-safety-psc { background-image: url(/image/app/hero/oem-psc2!p=1&q=30.jpg); background-position: 80% 80%; }
#hero-safety-ems { background-image: url(/image/app/hero/oem-ems!p=1&q=30.jpg); }
#hero-safety-fire { background-image: url(/image/app/hero/oem-fire2!p=1&q=30.jpg); background-position: center bottom; }
#hero-safety-pstf { background-image: url(/image/app/hero/pstf!p=1&q=30.jpg); }
#hero-safety-preparedness { background-image: url(/image/app/hero/health-prepare5!p=1&q=30.jpg); }
#hero-safety-safetysecurity { background-image: url(/image/app/hero/safety-security12!p=1&q=30.jpg); background-position: center center; }

#hero-safety-probations { background: url(hero/safety-dots.png) center /  8px 8px, linear-gradient(to bottom right, #051228 15%, #2f4d80, #051228 85%); }



#hero-cd { background-image: url(/image/app/hero/cd-office!p=1&q=30.jpg); }
#hero-acp { background-image: url(/image/app/hero/falls-night1!p=1&q=30.jpg); }

#hero-sheriff-news { background-image: url(/image/app/hero/safety!p=1&q=30.jpg); }
/*#hero-sheriff { background-image: url(/image/app/hero/sheriff-pano!p=1&q=30.jpg); }*/
/*#hero-sheriff { background-image: url(/image/app/hero/sheriff-car2!p=1&q=30.jpg); background-position: 75% bottom; }*/
#hero-sheriff { background-image: url(/image/app/hero/sheriff-staff!p=1&q=30.jpg); }
#hero-sheriff-about { background-image: url(/image/app/hero/sheriff!p=1&q=30.jpg); }
#hero-sheriff-policebureau { background-image: url(/image/app/hero/sheriff3!p=1&q=30.jpg); background-position: 75% bottom; }
#hero-sheriff-courtsecurity { background-image: url(/image/app/hero/sheriff-courtsecurity3!p=1&q=30.jpg); }
#hero-sheriff-jailbureau { background-image: url(/image/app/hero/sheriff-jailbureau2!p=1&q=30.jpg); background-position: center bottom; }
#hero-comserv { background-image: url(/image/app/hero/city9b!p=1&q=30.jpg); background-position: left bottom; }

#hero-dot { background-image: url(/image/app/hero/dot5!p=1&q=30.jpg); }
#hero-dot-planning { background-image: url(/image/app/hero/dot6!p=1&q=30.jpg); }
#hero-dot-standards { background-image: url(/image/app/hero/dot-bridgeops8!p=1&q=30.jpg); }   
#hero-dot-construction { background-image: url(/image/app/hero/dot-bridgeops2!p=1&q=30.jpg); }   
#hero-dot-hwybrdgops { background-image: url(/image/app/hero/dot3!p=1&q=30.jpg); }
#hero-dot-emaillist { background-image: url(/image/app/hero/dot-misc3!p=1&q=30.jpg); }
#hero-dot-trafficops { background-image: url(/image/app/hero/dot-truck2!p=1&q=30.jpg); }
#hero-dot-signalops { background-image: url(/image/app/hero/dot-rtoc19!p=1&q=30.jpg); background-position: center top; }
#hero-dot-proof-insurance { background-image: url(/image/app/hero/dot-misc2!p=1&q=30.jpg); }
#hero-dot-hwybrdgeng { background-image: url(/image/app/hero/dot-bridgeops4!p=1&q=30.jpg); background-position: center bottom; }
#hero-dot-bridgeororke { background-image: url(/image/app/hero/dot-bridgeororke2!p=1&q=30.jpg); }
#hero-dot-bridgestuart { background-image: url(/image/app/hero/dot-bridgestuart!p=1&q=30.jpg); }
#hero-dot-bridgeibob { background-image: url(/image/app/hero/dot-ibob5!p=1&q=30.jpg); }
#hero-dot-bridgeinventory { background-image: url(/image/app/hero/dot-ibob1!p=1&q=30.jpg); }
#hero-dot-faq { background-image: url(/image/app/hero/dot-ibob2!p=1&q=30.jpg); }
#hero-dot-completestreets { background-image: url(/image/app/hero/dot-streets1!p=1&q=30.jpg); }


#hero-vsa { background-image: url(/image/app/hero/vsa!p=1&q=30.jpg); }
#hero-vsa-contactus { background-image: url(/image/app/hero/veterans-building!p=1&q=30.jpg); }
#hero-vsa-benefits { background-image: url(/image/app/hero/vsa-benefits!p=1&q=30.jpg); background-position: center left; }
#hero-vsa-memorials { background-image: url(/image/app/hero/parks-beikirch4!p=1&q=30.jpg); }
#hero-vsa-parade { background-image: url(/app/hero/stars-overlay.png), linear-gradient(-45deg, #0d1d36, #1f3b71); background-size: auto; background-repeat: repeat; }
#hero-never-forget { background-image: url(/image/app/hero/vsa!p=1&q=30.jpg); }

#hero-executive-timetovote { background: linear-gradient(45deg, rgba(91,94,213,0) 50%, rgba(91,94,213,1) 100%), radial-gradient(#3692CB, #0D365A); }

#hero-eclipse-2024 { background: radial-gradient(circle, #02112B 50%, #32352b 50.1%, #02112B 70%); }

/* Menu specific head background colors */
.menu-vsa .head-bg::before { background-image: linear-gradient(45deg, #1B1F45 0 50%, #59090A 0 100%); }
.menu-hs .head-bg::before { 
	background-image: linear-gradient(rgba(0,0,0,.6), rgba(0,0,0,.6)), 
	url(/image/app/hero/colors1a!p=1&q=30.jpg); 
}
.menu-cii .head-bg::before { background-image: linear-gradient(45deg, #947C8E, #2B3F58); }
.menu-da .head-bg::before { background-image: linear-gradient(45deg, #14141B 50%, #8E4C24, #B29841); }
.menu-hdchild .head-bg::before { background-image: linear-gradient(45deg, #28a1a6, #c7aa2e, #b92e2f); }
/* .menu-hdchild .head-bg::before { background-image: linear-gradient(45deg, #5DE0E5, #FBDD5A, #F65758); } */
/*	.menu-hdchild #head { color: #000; fill: #000; border-color: #000; } */
.menu-health .head-bg::before { background-image: linear-gradient(45deg, #123A7F, #92ACF4); }
/*.page-health .head-bg::before { 
	background-image: linear-gradient(rgba(0,0,0,.6), rgba(0,0,0,.6)), 
	url(/image/app/hero/colors-blue!p=1&q=30.jpg); 
}*/
.menu-sheriff .head-bg::before,
.menu-comserv .head-bg::before { background-image: linear-gradient(45deg, #710117, #000, #0F0D95); }
.menu-mh .head-bg::before,
.menu-mhyouth .head-bg::before,
.menu-mhadult .head-bg::before { background-image: linear-gradient(45deg, #2B476B, #637DAC, #89B3E1); }
.menu-ts .head-bg::before { background-image: linear-gradient(45deg, #22262C 50%, #90473A); }
.menu-safety .head-bg::before { background-image: linear-gradient(45deg, #051228 50%, #F9B41B); }
.menu-hr .head-bg::before { background-image: linear-gradient(45deg, #222, #666); }
/*.menu-pstf .head-bg::before { background-image: linear-gradient(45deg, #2F4D6A, #7691A1); } */
.menu-gis .head-bg::before { background-image: linear-gradient(45deg, #80302A, #C5A539); }
.menu-parks .head-bg::before { background-image: linear-gradient(45deg, #2d4b25, #49793c); }
.menu-des .head-bg::before { background-image: linear-gradient(45deg, #30536E, #3D4A1C); }
.menu-clerk .head-bg::before { background-image: linear-gradient(45deg, #3D3738, #877878); }
.page-clerk-passports .head-bg::before { background-image: linear-gradient(-45deg, #131F3C, #3c528f); }
.menu-libra .head-bg::before { background-image: linear-gradient(45deg, #312E28, #847B70); }
.menu-communications .head-bg::before { background-image: linear-gradient(45deg, #7C7778, #55657E); }
.menu-dot .head-bg::before { background-image: linear-gradient(45deg, #32302F, #79716E); }
.menu-department .head-bg::before { background-image: linear-gradient(45deg, #C3A73F 0 50%, #176220 50% 100%); }
.menu-publicintegrity .head-bg::before { background-image: linear-gradient(45deg, #1C2B39, #9ca1a4); }
.menu-is .head-bg::before { background-image: linear-gradient(45deg, #002358, #0E7E8B); }
/*.menu-oem .head-bg::before { background-image: linear-gradient(45deg, #302C7E, #D4BF3F); }*/
.menu-mch .head-bg::before { background-image: linear-gradient(45deg, #C4641C, #8597C0); }
.menu-law .head-bg::before { background-image: linear-gradient(45deg, #2E3026, #8B6A4A); }
.menu-health .head-bg::before { background-image: linear-gradient(45deg, #, #); }
.menu-legislature .head-bg::before { background-image: linear-gradient(45deg, #192734, #345074); }
.menu-mcc .head-bg::before { background-image: linear-gradient(45deg, #231F20 50%, #D3A20B 50%); }
.menu-defender .head-bg::before { background-image: linear-gradient(45deg, #2D2D33, #423C3A); }
.menu-historian .head-bg::before { background-image: linear-gradient(45deg, #80614B, #32200B); }
.menu-youth .head-bg::before { background-image: linear-gradient(45deg, #F63448, #E5A81E); }
.menu-aging .head-bg::before { background-image: linear-gradient(45deg, #913335, #B87328); }
.menu-fbci .head-bg::before { background-image: linear-gradient(45deg, #182636, #576E80); }
.menu-elections .head-bg::before { background-image: linear-gradient(45deg, #16224C, #696969, #5A010A); }
.menu-finance .head-bg::before { background-image: linear-gradient(-30deg, #213b67, #10260c); }
.menu-planning .head-bg::before { background-image: linear-gradient(45deg, #607A95, #414A22); }
.menu-economic .head-bg::before { background-image: linear-gradient(45deg, #37793A, #80BB41); }
.menu-executive .head-bg::before { background-image: linear-gradient(45deg, #C3A73F, #176220); }
.menu-cd .head-bg::before { background-image: linear-gradient(45deg, #30201B, #906D62); }
.menu-purch .head-bg::before { background-image: linear-gradient(45deg, #7D7C82, #1E1D21); }
.menu-property .head-bg::before { background-image: linear-gradient(45deg, #132325, #708196); }
.menu-eh .head-bg::before { background-image: linear-gradient(45deg, #647C0C, #456180); }
.menu-dmv .head-bg::before { background-image: linear-gradient(45deg, #17181A, #883820); }
.menu-dei .head-bg::before { background-image: linear-gradient(45deg, #3F1455, #B31451); }
.menu-planforward .head-bg::before { background-image: linear-gradient(45deg, #113582 0 50%, #F9B81C 50% 100%); }
.menu-bringmonroeback .head-bg::before { background-image: linear-gradient(45deg, #F36E33, #6E4196, #d3137e); }
.menu-addiction .head-bg::before { background-image: linear-gradient(45deg, #5f1a86, #a059c1); }
.menu-opioid .head-bg::before { background-image: linear-gradient(45deg, #302A28 30%, #627F0D); }
.menu-acp .head-bg::before { background-image: linear-gradient(45deg, #861C45, #263267); }

.page-opioid-info .head-bg::before { background-image: linear-gradient(45deg, #5C717C, #17222B); }
.page-health-maternal-foster-care .head-bg::before { background-image: linear-gradient(45deg, #F77F1C, #EA5B94, #3299D7); }
.page-health-maternal-foster-care .head-bg::before { background-image: linear-gradient(45deg, #ab663d, #feb81c); }

/* .page-health-impact .head-bg::before { background-image: linear-gradient(45deg, #6D469D, #E73497); } */

.page-health-impact .head-bg::before { background-image: linear-gradient(45deg, #121640, #4472c4); }
.menu-irobay .head-bg::before { background-image: linear-gradient(45deg, #3E5F83, #6B6370); }
.page-hr-makeadifference .head-bg::before { background-image: linear-gradient(45deg, #003a6e, #968b87); }
.page-pride2022 .head-bg::before { background-image: linear-gradient(45deg,
	#C9422C 16%, 
	#DA5D3C 16%, #DA5D3C 33%, 
	#F3E049 33%, #F3E049 50%, 
	#BAD13C 50%, #BAD13C 66%,
	#49627A 66%, #49627A 83%,
	#774678 83%
);}
.page-vsa-parade .head-bg::before { background: linear-gradient(-45deg, #0d1d36, #1f3b71); }
.page-executive-timetovote .head-bg::before { background: linear-gradient(45deg, #0D365A, #3692CB, #5b5ed5); }

.page-parks-movies .head-bg::before { background-image: linear-gradient(45deg, #13466D, #081825); }
.page-parks-winterfest .head-bg::before { background-image: linear-gradient(45deg, #354a6c, #2a3a55); }
/*.page-parks-lilac .head-bg::before { background-image: linear-gradient(45deg, #A12975, #E4188A); } */
.page-parks-lilac .head-bg::before { background-image: linear-gradient(45deg, #7A3D7A, #D476AE); }
.page-eclipse-2024 .head-bg::before { background-image: linear-gradient(45deg, #02112B 50%, #32352b); }

.menu-ecopark .head-bg::before { background-image: linear-gradient(45deg, #14562E, #70C185); }

.is-front .head-bg::before { background-image: linear-gradient(45deg, #5A83A3, #142253); }

/* CKEditor Components */

/* Colored collapsible boxes */
.tbox { margin: 1rem 0; clear: both; }
.tbox:first-child { margin-top: 0; }
.tbox:last-child { margin-bottom: 0; }
.tbox + .tbox { margin-top: calc(-1rem + 2px); }
.tbox-txt { padding: 10px; border: 1px solid transparent; margin: 0; }
h3.tbox-title { padding: 10px 10px; font-family: inherit; font-size: 16px; font-weight: bold; color: #fff; margin: 0;  background: #000; position: relative; border: 1px solid transparent; }
.tbox-left { text-align: left; }
.tbox-right { text-align: right; }
.tbox-center { text-align: center; }
.tbox > a { text-decoration: none; }
.tbox > a[aria-controls] .tbox-title { padding-right: 54px; }
.tbox > a[aria-controls] .tbox-title::after { font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f067"; position: absolute; right: 10px; top: 10px; opacity: .6; }
.tbox > a[aria-controls][aria-expanded=true] .tbox-title::after { content: "\f146"; }
.has-js .tbox-closed .tbox-txt { display: none; /* Preclose boxed for slow js initialization */ }

.tbox-s-solid .tbox-txt { color: #fff; }
.tbox-s-solid .tbox-txt a { color: #fff; }
.tbox-s-solid .tbox-txt a:hover { color: rgba(255,255,255,.8); }
.tbox-s-solid .tbox-txt a:active { color: #fff; }

.tbox-s-solid a.btn { background: #fff; color: #000; }
.tbox-s-solid a.btn:hover { background: rgba(255,255,255,.8); }
.tbox-s-solid a.btn:active { background: rgba(0,0,0,.7); color: #fff; }

.tbox-c-grey .tbox-title,
.tbox-c-grey.tbox-s-solid .tbox-txt { background: #444444; }
.tbox-c-grey.tbox-s-border .tbox-txt,
.tbox-c-grey.tbox-s-lines .tbox-txt,
.tbox-c-grey.tbox-s-lines .tbox-title { border-color: #444444; }
.tbox-c-grey.tbox-s-lines .tbox-title { color: #444444; }
.tbox-c-grey.tbox-s-normal { background: #E8E8E8; }
.tbox-c-grey.tbox-s-solid .tbox-title { background: #303030; }

.tbox-c-blue .tbox-title,
.tbox-c-blue.tbox-s-solid .tbox-txt { background: #194E84; }
.tbox-c-blue.tbox-s-border .tbox-txt,
.tbox-c-blue.tbox-s-lines .tbox-txt,
.tbox-c-blue.tbox-s-lines .tbox-title { border-color: #194E84; }
.tbox-c-blue.tbox-s-lines .tbox-title { color: #194E84; }
.tbox-c-blue.tbox-s-normal { background: #D1DCE7; }
.tbox-c-blue.tbox-s-solid .tbox-title { background: #12375D; }

.tbox-c-green .tbox-title,
.tbox-c-green.tbox-s-solid .tbox-txt { background: #228418; }
.tbox-c-green.tbox-s-border .tbox-txt,
.tbox-c-green.tbox-s-lines .tbox-txt,
.tbox-c-green.tbox-s-lines .tbox-title { border-color: #228418; }
.tbox-c-green.tbox-s-lines .tbox-title { color: #228418; }
.tbox-c-green.tbox-s-normal { background: #D1E8D1; }
.tbox-c-green.tbox-s-solid .tbox-title { background: #155D12; }

.tbox-c-red .tbox-title,
.tbox-c-red.tbox-s-solid .tbox-txt { background: #841919; }
.tbox-c-red.tbox-s-border .tbox-txt,
.tbox-c-red.tbox-s-lines .tbox-txt,
.tbox-c-red.tbox-s-lines .tbox-title { border-color: #841919; }
.tbox-c-red.tbox-s-lines .tbox-title { color: #841919; }
.tbox-c-red.tbox-s-normal { background: #E7D1D1; }
.tbox-c-red.tbox-s-solid .tbox-title { background: #5D1212; }

.tbox-c-white .tbox-title,
.tbox-c-white.tbox-s-solid .tbox-txt { background: #E8E8E8; }
.tbox-c-white.tbox-s-border .tbox-txt,
.tbox-c-white.tbox-s-lines .tbox-txt,
.tbox-c-white.tbox-s-lines .tbox-title { border-color: #E8E8E8; }
.tbox-c-white.tbox-s-normal { background: #FFFFFF; }
.tbox-c-white.tbox-s-solid .tbox-title { background: #D8D8D8; }

.tbox-c-white .tbox-title, .tbox-c-white .tbox-txt { color: #000; }

.tbox-s-lines .tbox-title { background: #fff; color: #000; }
.tbox-title + .tbox-txt, .tbox > a + .tbox-txt { border-top: none; }
.tbox-txt > :first-child { margin-top: 0; }
.tbox-txt > :last-child { margin-bottom: 0; }

/* Float left/right boxes */
.float.float-l { float: left; clear: left; margin-right: 8px; margin-bottom: 8px; }
.float.float-r { float: right; clear: right; margin-left: 8px; margin-bottom: 8px; }
.float > :first-child { margin-top: 0; }
.float > :last-child { margin-bottom: 0; }
.float-1 { max-width: 8.333333%; }
.float-2 { max-width: 16.666667%; }
.float-3 { max-width: 25%; }
.float-4 { max-width: 33.333333%; }
.float-5 { max-width: 41.666667%; }
.float-6 { max-width: 50%; }

/* Tags */
.tag { background: #888; color: #fff; padding: 1px 6px; margin: -1px 0; text-decoration: none; border-radius: 6px; font-size: 80%; display: inline-block; }
.tag-red { background: #841919; }
.tag-green { background: #228418; }
a > .tag { color: #fff; margin-right: 5px; }

/* Very simple responsive column */
.rcols { margin: 1em 0; }
.rcols:first-child { margin-top: 0; }
.rcols:last-child { margin-bottom: 0; }
.rcols > div > ul { margin: 0; }
@media not all and (max-width: 780px) {
	.rcols { display: flex; margin: 1em -6px; }
	.rcols > * { flex: 1; margin: 0 6px; }	
	.rcols > * > :first-child { margin-top: 0; }
	.rcols > * > :last-child { margin-bottom: 0; }	
}

/* Video layout */
body.layout-video #page-title { text-align: center; }
body.layout-video #body { position: relative; }
body.layout-video #body::before { content: ''; background: radial-gradient(100% 100% at 50% 0%, #444, #222 50%); position: absolute; width: 100vw; height: 100%; left: calc(50% - 50vw); top: 0; z-index: -1; }
body.layout-video #main { color: #ddd; }
body.layout-video #main a { color: #fff; }

/* Embedded responsive video */
.embed-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; } 
.embed-container iframe, .embed-container object, .embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* Embed twitter */
.twitter-container { clear: both; max-width: 500px; width: 100%; margin-left: auto; margin-right: auto; border: 1px solid #ccc; }

/* Embed Facebook */
.fb-container { clear: both; max-width: 500px; width: 100%; margin-left: auto; margin-right: auto; border: 1px solid #ccc; overflow-x: hidden; }
.fb-container iframe { width: 100%; }







/* More link in home titles */
h2.home-sect-title { margin: 0 0 24px 0; text-align: center; font-family: inherit; }
.home-link-more { display: inline-block; margin: -4px 0 -4px 12px; padding: 4px 12px; border-left: 1px solid #888; text-decoration: none; }
.home-link-more:focus { outline-offset: -4px; }
#home-wrap { position: relative; }

/* Homepage carousel */
#carousel-wrap { padding-top: 50px; margin-top: -50px; position: relative; }
#carousel { padding-bottom: 4px; margin-top: -4px; margin-bottom: 24px; }
#carousel .slide { width: calc((1000px - 8px) / 3); max-width: calc((100vw - 64px) / 3); padding: 4px; }
#carousel .slide:active,
#carousel .slide:focus { outline-offset: -4px; outline: 4px solid #64acff; }
#carousel .slide img { display: block; }
@media not all and (min-width: 800px) {
	#carousel .slide { max-width: calc((100vw - 64px) / 2); }
}
@media not all and (min-width: 400px) {
	#carousel .slide { max-width: calc(100vw - 64px); }
}
#carousel .flickity-page-dots { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; bottom: -24px; height: 24px; padding: 0 12px; }
#carousel .flickity-page-dots .dot { display: block; margin: 0; height: 12px; width: 12px; border-radius: 0; background: transparent;  }
#carousel .flickity-page-dots .dot::before { 
	content: ''; display: block; border-radius: 50%; width: 100%; height: 100%; background: #444;
	background-clip: padding-box; border: 4px solid transparent;
}
#carousel .flickity-page-dots .dot.is-selected::before,
#carousel .flickity-page-dots .dot:hover::before { width: 100%; height: 100%; background: #222; border-width: 0; }
#carousel .flickity-prev-next-button { background: #222; color: #fff; width: 28px; height: 28px; text-align: center; border-radius: 0; opacity: 1; }
#carousel .flickity-prev-next-button:hover { background: #fff; color: #222; }
#carousel .previous:active svg { left: 0%; }
#carousel .next:active svg { left: 40%; }
#carousel .previous { left: 0px; }
#carousel .next { right: 0px; }



/*.slick-prev, .slick-next { z-index: 5; background: #000; color: #fff; width: 28px; height: 28px; text-align: center; border-radius: 0; box-shadow: none; }
.slick-prev::before, .slick-next::before { font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f053"; line-height: 28px; opacity: 1; color: inherit; }
.slick-next::before { content: "\f054"; }
.slick-prev { left: 12px; }
.slick-next { right: 12px; }
.slick-prev:focus, .slick-next:focus { background: #000; color: #fff; outline: 4px solid #64acff; }
.slick-prev:hover, .slick-next:hover { background: #fff; color: #000; }
.slick-prev:active { text-align: left; }
.slick-next:active { text-align: right; }
@media not all and (min-width: 700px) {
	.slick-prev { left: 0; }
	.slick-next { right: 0; }
}
.slick-dots { bottom: -21px; }
.slick-dots li { margin: 0; height: 16px; width: 16px; }
.slick-dots li button:before { height: 16px; width: 16px; line-height: 16px; }
.slick-dots li button { padding: 0; height: 16px; width: 16px; line-height: 16px; }
.slick-dots li.slick-active button:before { font-size: 16px; }
.slick-dots button { box-shadow: none; background: transparent !important; box-shadow: none !important; } */

/* Carousel hero bg */
.slide-bg { position: absolute; height: 100%; width: 100%; left: 0; top: 0; }
.slide-bg div	{ background-size: 100% 600px; background-repeat: no-repeat; /*background-attachment: fixed;*/ height: 100%; width: 100%; position: absolute; left: 0; top: 0; opacity: 0; }
.slide-bg div.slide-bg-show { transition: opacity .3s ease-out; opacity: 1; }

/* Home COVID-19 */
#home-covid-wrap { margin: 12px auto; max-width: 1024px; padding: 0 12px; }
#home-covid-border { padding: 6px; background: linear-gradient(45deg, #841919, #ff8080); }
#home-covid { background: #fff; padding: 12px; }

/* Home square links */
#home-links-wrap { max-width: 1024px; margin: 12px auto; padding: 0 12px; }
#home-links-crop { overflow: hidden; }
ul#home-links, #home-links li { list-style: none; padding: 0; margin: 0; }
ul#home-links { display: flex; flex-wrap: wrap; align-items: stretch; background: linear-gradient(45deg, #194E84, #64acff); /*margin: -1px -1px 0 -1px;*/ padding: 0 1px 1px 0; }
#home-links li { flex: 1 0 auto; }
#home-links a { padding-top: 100%; position: relative; display: block; line-height: 1.2; background: #fff; color: #000; text-align: center; margin: 1px 0 0 1px; }
#home-links a:hover,
#home-links a:focus { background: transparent; color: #fff; /*color: #64acff; */ outline-offset: -4px; }
#home-links a:active { background: transparent; color: #fff; border-color: #fff; }
#home-links a div { position: absolute; top: 0; left: 0; height: 100%; display: flex; flex-direction: column; width: 100%; align-items: center; padding: 0 4px; }
#home-links a div > * { display: block; height: 50%; margin: 0 4px; }
#home-links a .fa { flex: 0 0 auto; }
#home-links a span { /* padding: 0 8px; */ }

#home-links li { width: 50%; }
#home-links a .fa { font-size: calc(4.0vw * 3); display: flex; align-items: center; justify-content: center; opacity: .8; }
#home-links a span { font-size: calc(1.6vw * 3); }

@media (min-width: 400px) {
	#home-links li { width: 33.333%; }
	#home-links a .fa { font-size: calc(4.0vw * 2); }
	#home-links a span { font-size: calc(1.6vw * 2); }
}
@media (min-width: 600px) and (max-width: 799px) {
	#home-links li { width: 33.333%; }
	#home-links a { padding-top: 40%; text-align: left; }
	#home-links a div { flex-direction: row; }
	#home-links a div > * { height: auto; }
	/* #home-links li { width: 25%; } */
	#home-links a .fa { font-size: calc(4.0vw * 1.3); }
	#home-links a span { font-size: calc(1.6vw * 1.5); }
}
@media (min-width: 800px) {
	#home-links li { width: 16.666%; }
	#home-links a .fa { font-size: 4.0vw; }
	#home-links a span { font-size: 1.6vw; }
}
@media (min-width: 1000px) {
	#home-links a .fa { font-size: 40px; }
	#home-links a span { font-size: 16px; }
}

#home-links li.red .fa { opacity: 1; }
#home-links li.red a { background: #a00; color: #fff; box-shadow: 0px 0px 0 1px #000; }
#home-links li.red a:hover { background: #800; }
#home-links li.red a:active { background: #600; }

/* Home news */
.home-news-wrap { max-width: 1024px; margin: 24px auto; padding: 0 12px; }
.home-news ul, .home-news li { display: block; list-style: none; margin: 0; padding: 0; }
.home-news { margin: 0 -4px; overflow: hidden; }
.home-news-small ul { margin-top: -1px; }
@media (min-width: 700px) {
	.home-news ul { column-count: 2; column-gap: 16px; }
}
.home-news li { break-inside: avoid; }
.home-news a { display: block; text-decoration: none; padding: 0 4px; outline-offset: -4px; line-height: 1.2; }
.home-news-small a { margin-bottom: -1px; /* Outline overlap border */ }
.home-news-small a > div { padding: 12px 0 12px 0; border-top: 1px solid #B9CADB; }
.home-news-big a > div { padding: 4px 0 4px 0; }
.home-news a:not(:hover) { color: #222; }
.home-news a span.home-news-date { color: #888; font-style: italic; font-size: 14px; white-space: nowrap; }
.home-news a span.home-news-date::before { content: '| ' }
.home-news-big a > div { display: flex; align-items: flex-start; }
.home-news-img { background: linear-gradient(#eee, #ddd); margin-right: 8px; flex: 0 0 100px; }
.home-news-img img { display: block; }

/* Home events */
#home-events-wrap { max-width: 1024px; margin: 24px auto; padding: 0 12px; }
#home-events ul, #home-events li { display: block; list-style: none; margin: 0; padding: 0; }
#home-events { margin: 0 -4px; overflow: hidden; }
#home-events ul { margin-top: -1px; }
@media (min-width: 700px) {	
	#home-events ul { column-count: 3; column-gap: 16px; }
}
#home-events li { break-inside: avoid; }
#home-events a { display: block; text-decoration: none; padding: 0 4px; outline-offset: -4px; line-height: 1.2; margin-bottom: -1px; /* Outline overlap border */ }
#home-events a > div { padding: 12px 0 12px 0; border-top: 1px solid #B9CADB; }
#home-events a:not(:hover) { color: #222; }
#home-events a span { display: block; }
#home-events a span.event-loc,
#home-events a span.event-date { color: #888; display: block; font-style: italic; font-size: 14px; padding-top: 2px; }
.home-news span.event-loc,
.home-news span.event-date { color: #888; display: block; font-style: italic; font-size: 14px; padding-top: 2px; }



/* Home featured (ads) */
#prefoot { background: linear-gradient(45deg, #D1DCE6, #bfe1ff); padding: 12px; display: none; }
body:not(.nav-open).is-front #prefoot { display: block; }
@media(min-width: 700px) { /* Hide from mobile menu until you can hide for mobile submenus */
	body.nav-menu #prefoot,
	body.nav-search #prefoot { background: #222; display: block; }
}
#home-featured { max-width: 1000px; margin: 0 auto; }
ul#home-featured-ul { list-style: none; display: flex; flex-wrap: wrap; justify-content: center; margin: -1.42857143px; padding: 0; }
#home-featured li { padding: 1.42857143px; margin: 0; }
#home-featured a { display: block; }
#home-featured img { display: block; }

/* Home exec picture */
#home-exec-img { display: block; clip-path: circle(50% at center); border-radius: 999px; width: 160px; height: 160px; border: 8px solid #fff; overflow: hidden; }
#home-exec-img:focus { outline-offset: -8px; }
#home-exec-img img { display: block; width: 100%; height: 100%; }
#home-exec-links a { text-decoration: none; }
#home-exec-name { font-weight: 900; }
@media (min-width: 1320px) {
	#home-exec-wrap { position: absolute; top: calc((-160px / 2) - (24px)); left: calc(50% - 500px - 160px); text-align: center; }
	#home-exec-nt { font-size: 14px; line-height: 1.2; }
	#home-exec-links a span { display: none; }
}
@media not all and (min-width: 1320px) {
	#home-exec-wrap { background: linear-gradient(45deg, #D1DCE6, #bfe1ff); margin: 24px 0; }
	#home-exec-img { width: 120px; height: 120px; flex: 0 0 auto; margin: -36px 12px -36px 0; }
	#home-exec { max-width: 1024px; margin: 0 auto; display: flex; align-items: center; padding: 12px; }
	#home-exec-txt { color: #194E84; }
}
@media (max-width: 520px) {
	#home-exec-links a span { display: none; }
	#home-exec-nt { line-height: 1.2; }
}
@media (min-width: 521px) and (max-width: 1319px) {
	#home-exec-nt { line-height: inherit; font-size: 18px; }
	#home-exec-nt * { display: inline-block; margin-right: 12px; }
	#home-exec-links { display: flex; }
	#home-exec-links a { margin: 2px; padding: 4px 6px; background: rgba(255,255,255,.5); line-height: 1; border-radius: 6px; }
}
@media (min-width: 801px) and (max-width: 1319px) {
	#home-exec-txt { display: flex; align-items: center; }
}

@media (min-width: 1320px) {
	.is-front #logo > h1 { justify-content: center; }
	.is-front #logo-ex { display: none; }
	.is-front #logo-mc { margin: 0; }
}

/* News stories */
/*#stories { display: flex; margin: -12px; flex-wrap: wrap; font-size: 14px; }
#stories .story { padding: 12px; width: 100%; display: flex; align-items: flex-start; }
#stories h2 { font-size: 16px; margin: 0; }
#stories h2 a { text-decoration: none; }
#stories .story-img, #stories .story-img img { width: 200px; height: 150px; display: block; }
#stories .story-img, #stories .story-img img { }
#stories .story-date { font-style: italic; color: #888; margin: 0; }
#stories .story-img { flex: 0 0 auto; background: linear-gradient(to bottom, #eee, #ddd); }
#stories .story-txt { flex: 1; padding-left: 24px; }
@media not all and (min-width: 700px) {
	#stories .story-img { display: none; }
	#stories .story-txt { padding-left: 0; }
}*/
.news { display: flex; flex-wrap: wrap; flex-direction: row; margin: -6px; }
.news .news-item { width: calc(50% - 12px); margin: 6px; padding-bottom: 12px; text-decoration: none; color: #222; }
.news .news-item:hover { text-decoration: underline; }
.news .news-img { background: linear-gradient(to bottom, #eee, #ddd); }
.news img { display: block; width: 100%; height: auto; }
.news .news-date { color: #888; font-style: italic; font-size: 14px; }
@media(min-width: 700px) {
	.news .news-item { width: calc(33.333% - 12px); }
}


/* Content admin */
.content-body { position: relative; }
.admin-links { display: flex; font-size: 12px; align-items: center; }
.admin-links a { margin-right: 4px; padding: 2px 8px; text-align: center; background: #f08; color: #fff; text-decoration: none; }
.admin-links a:hover { background: #804; }
.admin-links a:active { color: #f08; background: #fff; }
.admin-links span { color: #f08; }

/* IE HACKS - remove eventually */
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
	.slide-bg { display: none !important; }
	.head-bg::before { height: 50px; }
}

/* Shift head boxes to top, partially over hero. Requires .img-circle on portrait. */
@media (min-width: 1320px) {
	#main div.head-box { float: none; margin: 0; position: absolute; top: calc(-160px / 2 - 36px); right: -160px; z-index: 50; width: 160px; padding: 8px; text-align: center; font-size: 14px; line-height: 1.2; }
	#main div.head-box img.img-circle { display: block; width: 160px !important; height: 160px !important; border: 8px solid #fff; margin: -8px -8px 0 -8px; max-width: 160px; }
	#main div.head-box img.img-circle + br { display: none; }
	#main div.head-box-left { left: -160px; right: auto; }
}

/* Select2 widget - also see input section */
#app .select2-container { max-width: 100%; }
#app .select2-selection { border: 1px solid #222; border-radius: 0; padding: 6px; height: auto; min-height: calc(1.5em + 14px); }
#app .select2-container--focus .select2-selection { outline: 4px solid #64acff; border-radius: 0; }
#app .select2-selection--single { padding-right: 20px; }
#app .select2-selection__rendered { line-height: inherit; padding: 0; }
#app .select2-selection__arrow { display: none; }
#app .select2-dropdown { border-radius: 0; border-color: #222; }
#app .select2-search__field { border-color: #222; }
#app .select2-search--dropdown { border-bottom: 1px solid #222; }
#app .select2-results__option { padding-top: 0; padding-bottom: 0; }
#app .select2-search--inline input { padding: 0; height: auto; margin: 0 0 1px 0; }
#app .select2-selection--multiple .select2-selection__rendered { display: block; margin-bottom: -1px; }
#app .select2-selection__choice { margin: 0 1px 1px 0; border: none; padding: 0 6px; }



/* Top site alert */
#site-alert { display: block; color: #fff; background: #a00; font-weight: 900; text-transform: uppercase; text-align: center; text-decoration: none; padding: 4px; border-bottom: 1px solid #fff; }
#site-alert:hover { background: #800; }
#site-alert:focus { outline-offset: -4px; }

@media print {
	html, body { color: #000; }
	#head-wrap { position: static; }
	#app .hero, #app .hero::before, #app .head-bg::before, #app .head-bg { background: none; }
	#app #head, #app .hero-txt h1 { text-shadow: none; color: #000; fill: #000; }
	#app #head svg, #app .hero-txt img { filter: none; }
	#skip, #side, #foot, #nav-btns, .hero-txt p.btns, #app #totop,
	#home-links-wrap, #home-exec, #carousel-wrap, #app #prefoot { display: none; }
	.hero { height: auto; }
}