/*  font definitions  */
@font-face{
    font-family: 'Source Sans Pro';
    font-weight: 400;
    font-style: normal;
    font-stretch: normal;
    src: url('type/SourceSansPro-Regular.eot') format('embedded-opentype'),
         url('type/SourceSansPro-Regular.ttf.woff2') format('woff2'),
         url('type/SourceSansPro-Regular.otf.woff') format('woff'),
         url('type/SourceSansPro-Regular.otf') format('opentype'),
         url('type/SourceSansPro-Regular.ttf') format('truetype');
}
@font-face{
    font-family: 'Source Sans Pro';
    font-weight: 300;
    font-style: normal;
    font-stretch: normal;
    src: url('type/SourceSansPro-Light.eot') format('embedded-opentype'),
         url('type/SourceSansPro-Light.ttf.woff2') format('woff2'),
         url('type/SourceSansPro-Light.otf.woff') format('woff'),
         url('type/SourceSansPro-Light.otf') format('opentype'),
         url('type/SourceSansPro-Light.ttf') format('truetype');
}
@font-face{
    font-family: 'Source Sans Pro';
    font-weight: 700;
    font-style: normal;
    font-stretch: normal;
    src: url('type/SourceSansPro-Semibold.eot') format('embedded-opentype'),
         url('type/SourceSansPro-Semibold.ttf.woff2') format('woff2'),
         url('type/SourceSansPro-Semibold.otf.woff') format('woff'),
         url('type/SourceSansPro-Semibold.otf') format('opentype'),
         url('type/SourceSansPro-Semibold.ttf') format('truetype');
}


/*  attributes for all  */
body, h1, h2, h3, h4, h5, h6, p, div, img, a, address, b, i, u, sup, div, span, ul, li {
	margin: 0;
	padding: 0;
	border: 0;
}

/*  tags  */
html
{
	-webkit-text-size-adjust: none;
}

body
{
	position: relative;
	font-family: 'Source Sans Pro', SourceSansPro, Verdana, Arial, Helvetica, sans-serif;
	background: #FEFFF4;
	color: #484848;
	text-align: center;
	font-size: 16px;
	margin: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a
{
	color: #AA0101;
	text-decoration: underline;
	transition: color 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
a:hover
{
	text-decoration: underline;
}


/*  ids  */
#skiptocontent
{
	position: absolute;
	display: inline-block;
	width: 10rem;
	height: 1.5rem;
	clip: rect(0,0,0,0);
	top: -2rem;
	left: 50%;
	margin: 0 0 0 -5rem;
	padding: .5rem;
	border: 0;
	white-space: nowrap;
	background-color: #F7F7F7;
	overflow: hidden;
	color: #000000;
	font-size: 1rem;
	line-height: 1.5em;
}
#skiptocontent:hover,
#skiptocontent:focus
{
	clip: auto;
	top: 2px;
}

main
{
	position: relative;
	display: block;
	overflow: visible;
}
main:after
{
	content: '';
	position: relative;
	display: block;
	width: 100%;
	height: 0;
	clear: both;
}
.home main
{
	padding-top: 1rem;
	padding-bottom: 1rem;
}




/*  classes  */
.high-contrast
{
	background: #FFFFFF;
	color: #000000;
	-webkit-filter: grayscale(100%);
	filter: grayscale(100%);
}
.high-contrast a
{
	color: #000000;
}

a:focus { box-shadow: 0 0 0 2px rgba(0, 0, 0, 1) !important; outline: 0; z-index: 2; }
#mobilenav a:focus { box-shadow: 0 0 0 2px rgba(0, 0, 0, 1) inset !important; }
.accordion .csc-header:focus { box-shadow: 0 0 0 2px rgba(0, 0, 0, 1) inset !important; }

.high-contrast :focus { box-shadow: 0 0 0 2px rgba(128, 128, 128, 1) !important; }
.high-contrast #mobilenav a:focus { box-shadow: 0 0 0 2px rgba(128, 128, 128, 1) inset !important; }
.high-contrast .accordion .csc-header:focus { box-shadow: 0 0 0 2px rgba(128, 128, 128, 1) inset !important; }

::-moz-focus-inner { border: 0; }