/* PowerSite 2.92 - Client: Stargate Connections Inc. - General CSS */
/* Last Updated: 2022.10.17 ET */

/* BASIC ELEMENT STYLES */

@import url('//fonts.googleapis.com/css?family=Josefin+Sans:400,400i,700,700i');

@font-face {
	font-family: 'Material Icons';
	font-style: normal;
	font-weight: 400;
	src: url('/includes/materialicons/MaterialIcons-Regular.woff2') format('woff2'),
		url('/includes/materialicons/MaterialIcons-Regular.woff') format('woff'),
		url('/includes/materialicons/MaterialIcons-Regular.ttf') format('truetype');
}

.material-icons,
span.mat-icon,
a[data-icon]::before,
a.cta.back::before,
a.cta.more::after,
a.filelink::after,
a[href^="http"]::after,
a[href$=".pdf"]::after,
a[href$=".xls"]::after,
a[href$=".xlsx"]::after,
a[href$=".doc"]::after,
a[href$=".docx"]::after,
a[href*="AA=Download"]::after,
dl.accordion dt::before {
	display: inline-block;
	vertical-align: text-top;
	font-family: 'Material Icons';
	font-weight: normal !important;
	font-style: normal !important;
	/* font-size: 24px;  Preferred icon size */
	font-size: 1em;
	line-height: 1;
	text-transform: none;
	letter-spacing: normal;
	word-wrap: normal;
	white-space: nowrap;
	direction: ltr;

	/* Support for all WebKit browsers. */
	-webkit-font-smoothing: antialiased;
	/* Support for Safari and Chrome. */
	text-rendering: optimizeLegibility;

	/* Support for Firefox. */
	-moz-osx-font-smoothing: grayscale;

	/* Support for IE. */
	font-feature-settings: 'liga';
}

a[data-icon]::before {
	content: attr(data-icon);
	vertical-align: text-top;
	margin-right: 0.5em;
}

html { font-size: 16px; }

body,
td,
th,
input,
select,
textarea,
button {
	color: rgb(101,107,111);
	font-family: 'Josefin Sans', sans-serif;
	font-weight: 400;
	font-size: 1.375rem; /* 1rem = 16px */
	line-height: 1.2em;
	letter-spacing: 0.02em;
    -webkit-text-size-adjust: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: rgb(59,61,64);
	font-weight: 400;
	margin-top: 0;
}

h1 {
	font-size: 3.25rem;
	line-height: 1em;
	text-align: center;
}

h1.headline {
	font-size: 2.75rem;
	line-height: 1.2em;
}

h2 {
	font-size: 2rem;
	line-height: 1.1em;
}

* + h2,
* + h3,
* + h4,
* + h5,
* + h6 { margin-top: 3rem; }

b,
strong {
	font-weight: 700;
}

a,
a:link,
a:visited {
	color: rgb(63,80,200);
}

a:hover {
	color: rgb(200,0,0);
}

th,
td {
	text-align: left;
	vertical-align: top;
	padding: 0.25em 1em 0.25em 0em;
}

sub {
	vertical-align: baseline;
	font-size: 0.6em;
}

sup {
	vertical-align: text-top;
	font-size: 0.6em;
}

code {
	background-color: rgb(255,255,204);
	font-size: 18px;
}

hr {
	display: block;
	clear: both;
	height: 1px;
	background-color: rgb(184,197,204);
	color: rgb(184,197,204);
	border: 0;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="file"],
input[type="url"],
input[type="number"],
input[type="tel"],
input[type="date"],
input[type="time"],
input[type="datetime"],
textarea {
	border: 1px solid rgb(127,157,185);
	padding: 0.2em 0.4em;
}

select {
	border: 1px solid rgb(127,157,185);
	padding: 0.1em 0.2em;
}

input[type="submit"],
input[type="reset"],
button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	min-height: 1.624rem;
}

input[type="submit"],
input[type="reset"],
button,
a.button {
	background: -moz-linear-gradient(top, rgb(255,255,255) 0%, rgb(230,230,230) 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgb(255,255,255)), color-stop(100%,rgb(230,230,230))); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top, rgb(255,255,255) 0%,rgb(230,230,230) 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top, rgb(255,255,255) 0%,rgb(230,230,230) 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top, rgb(255,255,255) 0%,rgb(230,230,230) 100%); /* IE10+ */
	background: linear-gradient(to bottom, rgb(255,255,255) 0%,rgb(230,230,230) 100%); /* W3C */
	padding: 0.2em 0.5em;
	border: 1px solid rgb(153,153,153);
	border-radius: 0.2em;
	color: rgb(59,61,64);
	font-size: 0.8em;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
}

input[type="submit"]:active,
button,
a.button:active {
	background: -moz-linear-gradient(top, rgb(230,230,230) 0%, rgb(255,255,255) 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgb(230,230,230)), color-stop(100%,rgb(255,255,255))); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top, rgb(230,230,230) 0%,rgb(255,255,255) 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top, rgb(230,230,230) 0%,rgb(255,255,255) 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top, rgb(230,230,230) 0%,rgb(255,255,255) 100%); /* IE10+ */
	background: linear-gradient(to bottom, rgb(230,230,230) 0%,rgb(255,255,255) 100%); /* W3C */
}

p.subhead {
	color: rgb(101,107,111);
	font-weight: 300;
	font-size: 1.5rem;
	line-height: 1.1em;
	text-align: center;
}

p.intro {
	font-weight: 300;
	font-size: 2.25rem;
	line-height: 1.2em;
}

article > p.intro:first-child {
	margin-top: -0.5em;
}

blockquote { margin: 1em auto; }

blockquote p {
	font-weight: 300;
	font-size: 1.6rem;
	line-height: 1.2em;
}

blockquote cite {
	display: block;
	font-weight: 400;
	font-style: normal;
	font-size: 0.8rem;
	line-height: 1.4em;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding-top: 1.4em;
	border-top: 1px solid rgb(146,166,175);
	margin: -1em auto 0;
}

blockquote cite > small {
	display: block;
	font-weight: 100;
	font-size: 0.8rem;
	letter-spacing: 0.02em;
	text-transform: none;
}


@media (max-width: 480px) {

	html { font-size: 12px; }

	h1 { font-size: 2.5rem; }

	blockquote p,
	p.intro {
		font-size: 1.5em;
	}

}

/* CUSTOM CLASSES */

.alert {
	color: rgb(240,0,0);
}

.note {
	color: rgb(99,127,140);
}

.notice {
	background-color: rgb(224,230,233);
	padding: 0.5em 1em;
}

.sect {
	margin-top: 2em!important;
}

.center {
	text-align: center;
}

.centerblock {
	margin-left: auto;
	margin-right: auto;
}

.floatright {
	float: right;
	margin-left: 1em;
}

.floatleft {
	float: left;
	margin-right: 1em;
}

.clearright {
	clear: right;
}

.clearleft {
	clear: left;
}

.clearboth {
	clear: both;
}

.num {
	text-align: right;
}

img.filethumb {
	display: inline-block;
	vertical-align: middle;
	margin-right: 1em;
	box-shadow: 0 0 0.5rem 0.1rem rgba(204,204,204,0.5);
}

dl.dated {
	max-width: 54rem;
	margin: 1em auto 3em;
}

dl.dated dt {
	font-weight: bold;
	font-size: 0.8em;
	margin-bottom: 0.5em;
}

dl.dated dd {
	margin-bottom: 1.5em;
}

dl.dated dd a {
	font-size: 1.2em;
}

div.charity {
	position: relative;
	overflow: hidden;
	color: rgb(99,127,140);
	padding: 0.5em;
	border: 1px solid rgb(184,197,204);
	margin: 1em auto;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

div.charity p {
	margin-left: 1em;
	margin-right: 1em;
    -webkit-flex: 1 1 0%;
    -ms-flex: 1 1 0%;
    flex: 1 1 0%;
}

div.charity img {
	float: left;
	margin-right: 1em;
}

table.specs,
table.grid {
	border-collapse: collapse;
}

table.specs th {
	color: rgb(99,127,140);
	border-bottom: 1px solid rgb(184,197,204);
}

table.specs td {
	border-bottom: 1px solid rgb(184,197,204);
}

table.grid th,
table.grid td {
	border-bottom: 1px solid rgb(184,197,204);
	padding: 0.5em 1.5em 0.5em 0em;
}

table.center th,
table.center td {
	text-align: center;
}

ul.expanded > li {
	margin-bottom: 1em;
}

ul.tabbar {
	list-style: none;
	padding: 0;
	margin: 1em 0;
}

ul.folders > li {
	margin-bottom: 0.5em;
	-webkit-column-break-inside: avoid; /* Chrome, Safari, Opera */
	page-break-inside: avoid; /* Firefox */
	break-inside: avoid; /* IE 10+ */
}

ul.folders > li > ul {
	font-size: 0.8em;
	line-height: 1.2;
	margin-top: 0.5em;
}

@media (min-width: 800px) {
	ul.folders {
		column-count: 2;
	}
}

@media (min-width: 1200px) {
	ul.folders {
		column-count: 3;
	}
}

ul.documents > li {
	margin-bottom: 1.5em;
}

ul.support > li,
ul.services > li {
	position: relative;
}

ul.support > li > a.adminlink,
ul.services > li > a.adminlink {
	position: absolute;
	bottom: 0;
	right: 0;
	color: rgb(240,0,0);
	font-size: 0.6em;
	padding: 0.2em;
	opacity: 0;
	transition: opacity 0.1s;
}

ul.support > li:hover > a.adminlink,
ul.services > li:hover > a.adminlink {
	opacity: 1;
}

ul.support span.mat-icon,
ul.services span.mat-icon {
	box-sizing: border-box;
	display: inline-block;
	width: 1.6em;
	height: 1.6em;
	background-color: rgb(149,171,183);
	color: white;
	font-size: 2em;
	line-height: 1.6;
	border-radius: 50%;
}

/* CONDITIONAL SELECTORS */

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child {
	margin-top: 0px;
}

h2 + h3 {
	margin-top: -0.4em;
}
