@import url("fontawesome-all.min.css");
@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,400italic,700,900");

/*
	Escape Velocity by HTML5 UP
	html5up.net | @ajlkn
	Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
*/

html, body, div, span, applet, object,
iframe, h1, h2, h3, h4, h5, h6, p, blockquote,
pre, a, abbr, acronym, address, big, cite,
code, del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b,
u, i, center, dl, dt, dd, ol, ul, li, fieldset,
form, label, legend, table, caption, tbody,
tfoot, thead, tr, th, td, article, aside,
canvas, details, embed, figure, figcaption,
footer, header, hgroup, menu, nav, output, ruby,
section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;

	}

	.formcontainer{
		max-width: 600px;
		margin:auto;
	}

	.formtitle {
		font-family: "rift-soft";
		font-weight: bold;
		color: white;
		font-size: 38px;
		text-align: left;
		margin-bottom: 20px;
	}

	.form-group label,.form-check label {
		font-family: "rift-soft";
		color: white;
	}

	/* Login page specific styles */
	.login-form .formtitle,
	.login-form label {
		color: white !important;
	}

	label {
		display: inline-block;
		margin-bottom: .5rem;
	}
	
	.form-group label ,.form-check label{
		font-family: "rift-soft";
		color: #312783;
	}
	label {
		display: inline-block;
		margin-bottom: .5rem;
		text-align: left;
	}
	input[type="text"], input[type="email"], textarea {
		background-color: #fff;
	}
	
	
	.btn-primary {
		color: #fff !important;
		background-color: #3d30a3 !important;
		border: none !important;
	}
	
	.btn {
    margin-top: 20px;
		font-weight: 400;
		color: #212529;
		text-align: center;
		vertical-align: middle;
		-webkit-user-select: none;
		-moz-user-select: none;
		-ms-user-select: none;
		user-select: none;
		background-color: transparent;
		border: 1px solid transparent;
		padding: .375rem .75rem;
		font-size: 1rem;
		line-height: 1.5;
		border-radius: .25rem;
		transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
	}

nav,#logo p,.title,.button.style3{
		font-family:'rift-soft';
	}
	
	#logo p.smaller{
		font-size:1.1em;
		margin-top:10px;
	}
	
	#nav > ul {
	height: 60px;
padding: 10px 8px;
	}
	
	div.title p{
		letter-spacing:0;
		font-size: 1.4em;
	}

.alert{
	display: block;
	width: auto;
	position: relative;
	padding: .75rem 1.25rem;
	border: 1px solid transparent;
		border-top-color: transparent;
		border-right-color: transparent;
		border-bottom-color: transparent;
		border-left-color: transparent;
	border-top-color: transparent;
	border-right-color: transparent;
	border-bottom-color: transparent;
	border-left-color: transparent;
	border-radius: .25rem;
	max-width: 90%;
	margin: auto auto 4rem;
	text-align: center;
	}


.alert-success {
		color: #155724;
		background-color: #d4edda;
		border-color: #c3e6cb;

	}

	.alert-danger {
		color: #721c24;
		background-color: #f8d7da;
		border-color: #f5c6cb;
	}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;}

body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

	blockquote:before, blockquote:after, q:before, q:after {
		content: '';
		content: none;
	}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

body {
	-webkit-text-size-adjust: none;
}

.homepage {
	background-color: #302682;
}

.nothomeheader {
	min-height: 400px !important;
	background: #fff !important;
	padding: 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-top: 30px !important;
}

/* Logonothome two-column layout */
.logonothome-container {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px;
}

.logonothome-left {
	width: 40%;
	text-align: right;
}

.logonothome-left img {
	max-width: 300px;
	height: auto;
}

.logonothome-right {
	width: 60%;
	text-align: left;
	padding-left: 30px;
}

.logonothome-right p {
	font-family: 'rift-soft';
	text-transform: uppercase;
	color: #302682;
	font-size: 1.4em !important;
	margin: 0 0 10px 0;
	line-height: 1.3;
}

.logonothome-right p .purplecol {
	color: #3d30a3;
}

.logonothome-right p.smaller {
	font-size: 1.2em !important;
	margin-top: 10px;
}

.logonothome-right p.smaller a {
	color: #302682;
	text-decoration: underline;
}

/* Responsive: stack vertically on small screens */
@media screen and (max-width: 736px) {
	.logonothome-container {
		flex-direction: column;
		padding: 15px;
	}

	.logonothome-left {
		width: 100%;
		margin-bottom: 20px;
		text-align: center;
	}

	.logonothome-left img {
		max-width: 200px;
	}

	.logonothome-right {
		width: 100%;
		text-align: center;
		padding-left: 0;
	}

	.logonothome-right p {
		font-size: 1em;
	}

	.logonothome-right p.smaller {
		font-size: 0.9em;
	}
}

mark {
	background-color: transparent;
	color: inherit;
}

input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

input, select, textarea {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
}

/* Basic */

	@-ms-viewport {
		width: device-width;
	}

	html {
		box-sizing: border-box;
	}

	*, *:before, *:after {
		box-sizing: inherit;
	}

	body.is-preload *, body.is-preload *:before, body.is-preload *:after {
		-moz-animation: none !important;
		-webkit-animation: none !important;
		-ms-animation: none !important;
		animation: none !important;
		-moz-transition: none !important;
		-webkit-transition: none !important;
		-ms-transition: none !important;
		transition: none !important;
	}

	body, input, textarea, select {
		font-family: 'Source Sans Pro', sans-serif;
		font-weight: 400;
		color: #5a5d65;
		font-size: 20px;
		line-height: 1.75em;
		letter-spacing: 0.025em;
	}

	h1, h2, h3, h4, h5, h6 {
		font-weight: 700;
		color: #484d55;
	}

	h1 { font-size: 2em; }
	h2 { font-size: 1.5em; }
	h3 { font-size: 1.25em; }
	h4 { font-size: 1.1em; }
	h5 { font-size: 1em; }
	h6 { font-size: 0.9em; }

		h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
			color: inherit;
			text-decoration: none;
		}

	a {
		-moz-transition: color .25s ease-in-out;
		-webkit-transition: color .25s ease-in-out;
		-ms-transition: color .25s ease-in-out;
		transition: color .25s ease-in-out;
		text-decoration: underline;
		color: #717479;
	}

		a:hover {
			text-decoration: none;
		}

	strong, b {
		font-weight: 700;
		color: #484d55;
	}

	blockquote {
		border-left: solid 8px #ddd;
		padding: 16px 0 16px 32px;
		font-style: italic;
	}

	em, i {
		font-style: italic;
	}

	hr {
		border: 0;
		border-top: solid 1px #ddd;
		margin: 32px 0 32px 0;
	}

	sub {
		position: relative;
		top: 8px;
		font-size: 13px;
	}

	sup {
		position: relative;
		top: -0.5em;
		font-size: 13px;
	}

	.nobr {
		white-space: nowrap;
	}

	br.clear {
		clear: both;
	}

	p, ul, ol, dl, table, blockquote, form {
		margin-bottom: 32px;
	}

/* Container */

	.container {
		margin: 0 auto;
		max-width: 100%;
		width: 72em;
	}

		@media screen and (max-width: 1680px) {

			.container {
				width: 75em;
			}

		}

		@media screen and (max-width: 1280px) {

			.container {
				width: calc(100% - 100px);
			}

		}

		@media screen and (max-width: 980px) {

			.container {
				width: calc(100% - 100px);
			}

		}

		@media screen and (max-width: 736px) {

			.container {
				width: calc(100% - 40px);
			}

		}

/* Row */

	.row {
		display: flex;
		flex-wrap: wrap;
		box-sizing: border-box;
		align-items: stretch;
	}

		.row > * {
			box-sizing: border-box;
		}

		.row.gtr-uniform > * > :last-child {
			margin-bottom: 0;
		}

		.row.aln-left {
			justify-content: flex-start;
		}

		.row.aln-center {
			justify-content: center;
		}

		.row.aln-right {
			justify-content: flex-end;
		}

		.row.aln-top {
			align-items: flex-start;
		}

		.row.aln-middle {
			align-items: center;
		}

		.row.aln-bottom {
			align-items: flex-end;
		}

		.row > .imp {
			order: -1;
		}

		.row > .col-1 {
			width: 8.33333%;
		}

		.row > .off-1 {
			margin-left: 8.33333%;
		}

		.row > .col-2 {
			width: 16.66667%;
		}

		.row > .off-2 {
			margin-left: 16.66667%;
		}

		.row > .col-3 {
			width: 25%;
		}

		.row > .off-3 {
			margin-left: 25%;
		}

		.row > .col-4 {
			width: 33.33333%;
		}

		.row > .off-4 {
			margin-left: 33.33333%;
		}

		.row > .col-5 {
			width: 41.66667%;
		}

		.row > .off-5 {
			margin-left: 41.66667%;
		}

		.row > .col-6 {
			width: 50%;
		}

		.row > .off-6 {
			margin-left: 50%;
		}

		.row > .col-7 {
			width: 58.33333%;
		}

		.row > .off-7 {
			margin-left: 58.33333%;
		}

		.row > .col-8 {
			width: 66.66667%;
		}

		.row > .off-8 {
			margin-left: 66.66667%;
		}

		.row > .col-9 {
			width: 75%;
		}

		.row > .off-9 {
			margin-left: 75%;
		}

		.row > .col-10 {
			width: 83.33333%;
		}

		.row > .off-10 {
			margin-left: 83.33333%;
		}

		.row > .col-11 {
			width: 91.66667%;
		}

		.row > .off-11 {
			margin-left: 91.66667%;
		}

		.row > .col-12 {
			width: 100%;
		}

		.row > .off-12 {
			margin-left: 100%;
		}

		.row.gtr-0 {
			margin-top: 0px;
			margin-left: 0px;
		}

			.row.gtr-0 > * {
				padding: 0px 0 0 0px;
			}

			.row.gtr-0.gtr-uniform {
				margin-top: 0px;
			}

				.row.gtr-0.gtr-uniform > * {
					padding-top: 0px;
				}

		.row.gtr-25 {
			margin-top: -12.5px;
			margin-left: -12.5px;
		}

			.row.gtr-25 > * {
				padding: 12.5px 0 0 12.5px;
			}

			.row.gtr-25.gtr-uniform {
				margin-top: -12.5px;
			}

				.row.gtr-25.gtr-uniform > * {
					padding-top: 12.5px;
				}

		.row.gtr-50 {
			margin-top: -25px;
			margin-left: -25px;
		}

			.row.gtr-50 > * {
				padding: 25px 0 0 25px;
			}

			.row.gtr-50.gtr-uniform {
				margin-top: -25px;
			}

				.row.gtr-50.gtr-uniform > * {
					padding-top: 25px;
				}

		.row {
			margin-top: -50px;
			margin-left: -50px;
		}

			.row > * {
				padding: 50px 0 0 50px;
			}

			.row.gtr-uniform {
				margin-top: -50px;
			}

				.row.gtr-uniform > * {
					padding-top: 50px;
				}

		.row.gtr-150 {
			margin-top: -75px;
			margin-left: -75px;
		}

			.row.gtr-150 > * {
				padding: 75px 0 0 75px;
			}

			.row.gtr-150.gtr-uniform {
				margin-top: -75px;
			}

				.row.gtr-150.gtr-uniform > * {
					padding-top: 75px;
				}

		.row.gtr-200 {
			margin-top: -100px;
			margin-left: -100px;
		}

			.row.gtr-200 > * {
				padding: 100px 0 0 100px;
			}

			.row.gtr-200.gtr-uniform {
				margin-top: -100px;
			}

				.row.gtr-200.gtr-uniform > * {
					padding-top: 100px;
				}

		@media screen and (max-width: 1680px) {

			.row {
				display: flex;
				flex-wrap: wrap;
				box-sizing: border-box;
				align-items: stretch;
			}

				.row > * {
					box-sizing: border-box;
				}

				.row.gtr-uniform > * > :last-child {
					margin-bottom: 0;
				}

				.row.aln-left {
					justify-content: flex-start;
				}

				.row.aln-center {
					justify-content: center;
				}

				.row.aln-right {
					justify-content: flex-end;
				}

				.row.aln-top {
					align-items: flex-start;
				}

				.row.aln-middle {
					align-items: center;
				}

				.row.aln-bottom {
					align-items: flex-end;
				}

				.row > .imp-xlarge {
					order: -1;
				}

				.row > .col-1-xlarge {
					width: 8.33333%;
				}

				.row > .off-1-xlarge {
					margin-left: 8.33333%;
				}

				.row > .col-2-xlarge {
					width: 16.66667%;
				}

				.row > .off-2-xlarge {
					margin-left: 16.66667%;
				}

				.row > .col-3-xlarge {
					width: 25%;
				}

				.row > .off-3-xlarge {
					margin-left: 25%;
				}

				.row > .col-4-xlarge {
					width: 33.33333%;
				}

				.row > .off-4-xlarge {
					margin-left: 33.33333%;
				}

				.row > .col-5-xlarge {
					width: 41.66667%;
				}

				.row > .off-5-xlarge {
					margin-left: 41.66667%;
				}

				.row > .col-6-xlarge {
					width: 50%;
				}

				.row > .off-6-xlarge {
					margin-left: 50%;
				}

				.row > .col-7-xlarge {
					width: 58.33333%;
				}

				.row > .off-7-xlarge {
					margin-left: 58.33333%;
				}

				.row > .col-8-xlarge {
					width: 66.66667%;
				}

				.row > .off-8-xlarge {
					margin-left: 66.66667%;
				}

				.row > .col-9-xlarge {
					width: 75%;
				}

				.row > .off-9-xlarge {
					margin-left: 75%;
				}

				.row > .col-10-xlarge {
					width: 83.33333%;
				}

				.row > .off-10-xlarge {
					margin-left: 83.33333%;
				}

				.row > .col-11-xlarge {
					width: 91.66667%;
				}

				.row > .off-11-xlarge {
					margin-left: 91.66667%;
				}

				.row > .col-12-xlarge {
					width: 100%;
				}

				.row > .off-12-xlarge {
					margin-left: 100%;
				}

				.row.gtr-0 {
					margin-top: 0px;
					margin-left: 0px;
				}

					.row.gtr-0 > * {
						padding: 0px 0 0 0px;
					}

					.row.gtr-0.gtr-uniform {
						margin-top: 0px;
					}

						.row.gtr-0.gtr-uniform > * {
							padding-top: 0px;
						}

				.row.gtr-25 {
					margin-top: -12.5px;
					margin-left: -12.5px;
				}

					.row.gtr-25 > * {
						padding: 12.5px 0 0 12.5px;
					}

					.row.gtr-25.gtr-uniform {
						margin-top: -12.5px;
					}

						.row.gtr-25.gtr-uniform > * {
							padding-top: 12.5px;
						}

				.row.gtr-50 {
					margin-top: -25px;
					margin-left: -25px;
				}

					.row.gtr-50 > * {
						padding: 25px 0 0 25px;
					}

					.row.gtr-50.gtr-uniform {
						margin-top: -25px;
					}

						.row.gtr-50.gtr-uniform > * {
							padding-top: 25px;
						}

				.row {
					margin-top: -50px;
					margin-left: -50px;
				}

					.row > * {
						padding: 50px 0 0 50px;
					}

					.row.gtr-uniform {
						margin-top: -50px;
					}

						.row.gtr-uniform > * {
							padding-top: 50px;
						}

				.row.gtr-150 {
					margin-top: -75px;
					margin-left: -75px;
				}

					.row.gtr-150 > * {
						padding: 75px 0 0 75px;
					}

					.row.gtr-150.gtr-uniform {
						margin-top: -75px;
					}

						.row.gtr-150.gtr-uniform > * {
							padding-top: 75px;
						}

				.row.gtr-200 {
					margin-top: -100px;
					margin-left: -100px;
				}

					.row.gtr-200 > * {
						padding: 100px 0 0 100px;
					}

					.row.gtr-200.gtr-uniform {
						margin-top: -100px;
					}

						.row.gtr-200.gtr-uniform > * {
							padding-top: 100px;
						}

		}

		@media screen and (max-width: 1280px) {

			.row {
				display: flex;
				flex-wrap: wrap;
				box-sizing: border-box;
				align-items: stretch;
			}

				.row > * {
					box-sizing: border-box;
				}

				.row.gtr-uniform > * > :last-child {
					margin-bottom: 0;
				}

				.row.aln-left {
					justify-content: flex-start;
				}

				.row.aln-center {
					justify-content: center;
				}

				.row.aln-right {
					justify-content: flex-end;
				}

				.row.aln-top {
					align-items: flex-start;
				}

				.row.aln-middle {
					align-items: center;
				}

				.row.aln-bottom {
					align-items: flex-end;
				}

				.row > .imp-large {
					order: -1;
				}

				.row > .col-1-large {
					width: 8.33333%;
				}

				.row > .off-1-large {
					margin-left: 8.33333%;
				}

				.row > .col-2-large {
					width: 16.66667%;
				}

				.row > .off-2-large {
					margin-left: 16.66667%;
				}

				.row > .col-3-large {
					width: 25%;
				}

				.row > .off-3-large {
					margin-left: 25%;
				}

				.row > .col-4-large {
					width: 33.33333%;
				}

				.row > .off-4-large {
					margin-left: 33.33333%;
				}

				.row > .col-5-large {
					width: 41.66667%;
				}

				.row > .off-5-large {
					margin-left: 41.66667%;
				}

				.row > .col-6-large {
					width: 50%;
				}

				.row > .off-6-large {
					margin-left: 50%;
				}

				.row > .col-7-large {
					width: 58.33333%;
				}

				.row > .off-7-large {
					margin-left: 58.33333%;
				}

				.row > .col-8-large {
					width: 66.66667%;
				}

				.row > .off-8-large {
					margin-left: 66.66667%;
				}

				.row > .col-9-large {
					width: 75%;
				}

				.row > .off-9-large {
					margin-left: 75%;
				}

				.row > .col-10-large {
					width: 83.33333%;
				}

				.row > .off-10-large {
					margin-left: 83.33333%;
				}

				.row > .col-11-large {
					width: 91.66667%;
				}

				.row > .off-11-large {
					margin-left: 91.66667%;
				}

				.row > .col-12-large {
					width: 100%;
				}

				.row > .off-12-large {
					margin-left: 100%;
				}

				.row.gtr-0 {
					margin-top: 0px;
					margin-left: 0px;
				}

					.row.gtr-0 > * {
						padding: 0px 0 0 0px;
					}

					.row.gtr-0.gtr-uniform {
						margin-top: 0px;
					}

						.row.gtr-0.gtr-uniform > * {
							padding-top: 0px;
						}

				.row.gtr-25 {
					margin-top: -8.75px;
					margin-left: -8.75px;
				}

					.row.gtr-25 > * {
						padding: 8.75px 0 0 8.75px;
					}

					.row.gtr-25.gtr-uniform {
						margin-top: -8.75px;
					}

						.row.gtr-25.gtr-uniform > * {
							padding-top: 8.75px;
						}

				.row.gtr-50 {
					margin-top: -17.5px;
					margin-left: -17.5px;
				}

					.row.gtr-50 > * {
						padding: 17.5px 0 0 17.5px;
					}

					.row.gtr-50.gtr-uniform {
						margin-top: -17.5px;
					}

						.row.gtr-50.gtr-uniform > * {
							padding-top: 17.5px;
						}

				.row {
					margin-top: -35px;
					margin-left: -35px;
				}

					.row > * {
						padding: 35px 0 0 35px;
					}

					.row.gtr-uniform {
						margin-top: -35px;
					}

						.row.gtr-uniform > * {
							padding-top: 35px;
						}

				.row.gtr-150 {
					margin-top: -52.5px;
					margin-left: -52.5px;
				}

					.row.gtr-150 > * {
						padding: 52.5px 0 0 52.5px;
					}

					.row.gtr-150.gtr-uniform {
						margin-top: -52.5px;
					}

						.row.gtr-150.gtr-uniform > * {
							padding-top: 52.5px;
						}

				.row.gtr-200 {
					margin-top: -70px;
					margin-left: -70px;
				}

					.row.gtr-200 > * {
						padding: 70px 0 0 70px;
					}

					.row.gtr-200.gtr-uniform {
						margin-top: -70px;
					}

						.row.gtr-200.gtr-uniform > * {
							padding-top: 70px;
						}

		}

		@media screen and (max-width: 980px) {

			.row {
				display: flex;
				flex-wrap: wrap;
				box-sizing: border-box;
				align-items: stretch;
			}

				.row > * {
					box-sizing: border-box;
				}

				.row.gtr-uniform > * > :last-child {
					margin-bottom: 0;
				}

				.row.aln-left {
					justify-content: flex-start;
				}

				.row.aln-center {
					justify-content: center;
				}

				.row.aln-right {
					justify-content: flex-end;
				}

				.row.aln-top {
					align-items: flex-start;
				}

				.row.aln-middle {
					align-items: center;
				}

				.row.aln-bottom {
					align-items: flex-end;
				}

				.row > .imp-medium {
					order: -1;
				}

				.row > .col-1-medium {
					width: 8.33333%;
				}

				.row > .off-1-medium {
					margin-left: 8.33333%;
				}

				.row > .col-2-medium {
					width: 16.66667%;
				}

				.row > .off-2-medium {
					margin-left: 16.66667%;
				}

				.row > .col-3-medium {
					width: 25%;
				}

				.row > .off-3-medium {
					margin-left: 25%;
				}

				.row > .col-4-medium {
					width: 33.33333%;
				}

				.row > .off-4-medium {
					margin-left: 33.33333%;
				}

				.row > .col-5-medium {
					width: 41.66667%;
				}

				.row > .off-5-medium {
					margin-left: 41.66667%;
				}

				.row > .col-6-medium {
					width: 50%;
				}

				.row > .off-6-medium {
					margin-left: 50%;
				}

				.row > .col-7-medium {
					width: 58.33333%;
				}

				.row > .off-7-medium {
					margin-left: 58.33333%;
				}

				.row > .col-8-medium {
					width: 66.66667%;
				}

				.row > .off-8-medium {
					margin-left: 66.66667%;
				}

				.row > .col-9-medium {
					width: 75%;
				}

				.row > .off-9-medium {
					margin-left: 75%;
				}

				.row > .col-10-medium {
					width: 83.33333%;
				}

				.row > .off-10-medium {
					margin-left: 83.33333%;
				}

				.row > .col-11-medium {
					width: 91.66667%;
				}

				.row > .off-11-medium {
					margin-left: 91.66667%;
				}

				.row > .col-12-medium {
					width: 100%;
				}

				.row > .off-12-medium {
					margin-left: 100%;
				}

				.row.gtr-0 {
					margin-top: 0px;
					margin-left: 0px;
				}

					.row.gtr-0 > * {
						padding: 0px 0 0 0px;
					}

					.row.gtr-0.gtr-uniform {
						margin-top: 0px;
					}

						.row.gtr-0.gtr-uniform > * {
							padding-top: 0px;
						}

				.row.gtr-25 {
					margin-top: -12.5px;
					margin-left: -12.5px;
				}

					.row.gtr-25 > * {
						padding: 12.5px 0 0 12.5px;
					}

					.row.gtr-25.gtr-uniform {
						margin-top: -12.5px;
					}

						.row.gtr-25.gtr-uniform > * {
							padding-top: 12.5px;
						}

				.row.gtr-50 {
					margin-top: -25px;
					margin-left: -25px;
				}

					.row.gtr-50 > * {
						padding: 25px 0 0 25px;
					}

					.row.gtr-50.gtr-uniform {
						margin-top: -25px;
					}

						.row.gtr-50.gtr-uniform > * {
							padding-top: 25px;
						}

				.row {
					margin-top: -50px;
					margin-left: -50px;
				}

					.row > * {
						padding: 50px 0 0 50px;
					}

					.row.gtr-uniform {
						margin-top: -50px;
					}

						.row.gtr-uniform > * {
							padding-top: 50px;
						}

				.row.gtr-150 {
					margin-top: -75px;
					margin-left: -75px;
				}

					.row.gtr-150 > * {
						padding: 75px 0 0 75px;
					}

					.row.gtr-150.gtr-uniform {
						margin-top: -75px;
					}

						.row.gtr-150.gtr-uniform > * {
							padding-top: 75px;
						}

				.row.gtr-200 {
					margin-top: -100px;
					margin-left: -100px;
				}

					.row.gtr-200 > * {
						padding: 100px 0 0 100px;
					}

					.row.gtr-200.gtr-uniform {
						margin-top: -100px;
					}

						.row.gtr-200.gtr-uniform > * {
							padding-top: 100px;
						}

		}

		@media screen and (max-width: 736px) {

			.row {
				display: flex;
				flex-wrap: wrap;
				box-sizing: border-box;
				align-items: stretch;
			}

				.row > * {
					box-sizing: border-box;
				}

				.row.gtr-uniform > * > :last-child {
					margin-bottom: 0;
				}

				.row.aln-left {
					justify-content: flex-start;
				}

				.row.aln-center {
					justify-content: center;
				}

				.row.aln-right {
					justify-content: flex-end;
				}

				.row.aln-top {
					align-items: flex-start;
				}

				.row.aln-middle {
					align-items: center;
				}

				.row.aln-bottom {
					align-items: flex-end;
				}

				.row > .imp-small {
					order: -1;
				}

				.row > .col-1-small {
					width: 8.33333%;
				}

				.row > .off-1-small {
					margin-left: 8.33333%;
				}

				.row > .col-2-small {
					width: 16.66667%;
				}

				.row > .off-2-small {
					margin-left: 16.66667%;
				}

				.row > .col-3-small {
					width: 25%;
				}

				.row > .off-3-small {
					margin-left: 25%;
				}

				.row > .col-4-small {
					width: 33.33333%;
				}

				.row > .off-4-small {
					margin-left: 33.33333%;
				}

				.row > .col-5-small {
					width: 41.66667%;
				}

				.row > .off-5-small {
					margin-left: 41.66667%;
				}

				.row > .col-6-small {
					width: 50%;
				}

				.row > .off-6-small {
					margin-left: 50%;
				}

				.row > .col-7-small {
					width: 58.33333%;
				}

				.row > .off-7-small {
					margin-left: 58.33333%;
				}

				.row > .col-8-small {
					width: 66.66667%;
				}

				.row > .off-8-small {
					margin-left: 66.66667%;
				}

				.row > .col-9-small {
					width: 75%;
				}

				.row > .off-9-small {
					margin-left: 75%;
				}

				.row > .col-10-small {
					width: 83.33333%;
				}

				.row > .off-10-small {
					margin-left: 83.33333%;
				}

				.row > .col-11-small {
					width: 91.66667%;
				}

				.row > .off-11-small {
					margin-left: 91.66667%;
				}

				.row > .col-12-small {
					width: 100%;
				}

				.row > .off-12-small {
					margin-left: 100%;
				}

				.row.gtr-0 {
					margin-top: 0px;
					margin-left: 0px;
				}

					.row.gtr-0 > * {
						padding: 0px 0 0 0px;
					}

					.row.gtr-0.gtr-uniform {
						margin-top: 0px;
					}

						.row.gtr-0.gtr-uniform > * {
							padding-top: 0px;
						}

				.row.gtr-25 {
					margin-top: -7.5px;
					margin-left: -7.5px;
				}

					.row.gtr-25 > * {
						padding: 7.5px 0 0 7.5px;
					}

					.row.gtr-25.gtr-uniform {
						margin-top: -7.5px;
					}

						.row.gtr-25.gtr-uniform > * {
							padding-top: 7.5px;
						}

				.row.gtr-50 {
					margin-top: -15px;
					margin-left: -15px;
				}

					.row.gtr-50 > * {
						padding: 15px 0 0 15px;
					}

					.row.gtr-50.gtr-uniform {
						margin-top: -15px;
					}

						.row.gtr-50.gtr-uniform > * {
							padding-top: 15px;
						}

				.row {
					margin-top: -30px;
					margin-left: -30px;
				}

					.row > * {
						padding: 30px 0 0 30px;
					}

					.row.gtr-uniform {
						margin-top: -30px;
					}

						.row.gtr-uniform > * {
							padding-top: 30px;
						}

				.row.gtr-150 {
					margin-top: -45px;
					margin-left: -45px;
				}

					.row.gtr-150 > * {
						padding: 45px 0 0 45px;
					}

					.row.gtr-150.gtr-uniform {
						margin-top: -45px;
					}

						.row.gtr-150.gtr-uniform > * {
							padding-top: 45px;
						}

				.row.gtr-200 {
					margin-top: -60px;
					margin-left: -60px;
				}

					.row.gtr-200 > * {
						padding: 60px 0 0 60px;
					}

					.row.gtr-200.gtr-uniform {
						margin-top: -60px;
					}

						.row.gtr-200.gtr-uniform > * {
							padding-top: 60px;
						}

		}

/* Section/Article */

	section,
	article {
		margin: 0 0 64px 0;
	}

	section > :last-child,
	article > :last-child,
	section:last-child,
	article:last-child {
		margin-bottom: 0;
	}

	header.style1 {
		text-align: center;
		padding: 48px 0 48px 0;
	}

		header.style1 h2 {
			font-weight: 700;
			font-size: 26px;
			letter-spacing: 0.075em;
			line-height: 24px;
			color:#2e294f;
		}

		header.style1 p {
			color: #302682;
			display: block;
			margin: 18px 0 0 0;
			font-size: 1.1em;
			letter-spacing: 0.075em;
			line-height: 24px;
		}

/* Table */

	table {
		width: 100%;
	}

		table.default {
			width: 100%;
		}

			/* COMMENTED OUT - nth-child not recommended */
			/* table.default tbody tr:nth-child(2n+2) {
				background: #f4f4f4;
			} */

			table.default td {
				padding: 8px 16px 8px 16px;
			}

			table.default th {
				text-align: left;
				font-weight: 400;
				padding: 8px 16px 8px 16px;
			}

			table.default thead {
				background: #484d55;
				color: #fff;
			}

			table.default tfoot {
				background: #eee;
			}

/* Form */

	form label {
		display: block;
		font-weight: 700;
		color: #484d55;
		margin: 4px 0 8px 0;
	}

	form input[type="text"],
	form input[type="email"],
	form input[type="password"],
	form select,
	form textarea {
		-moz-transition: all .25s ease-in-out;
		-webkit-transition: all .25s ease-in-out;
		-ms-transition: all .25s ease-in-out;
		transition: all .25s ease-in-out;
		-webkit-appearance: none;
		display: block;
		border: 0;
		background: #eee;
		box-shadow: inset 0px 0px 1px 0px #a0a1a7;
		border-radius: 0.35em;
		width: 100%;
		padding: 12px 16px 12px 16px;
	}

		form input[type="text"]:focus,
		form input[type="email"]:focus,
		form input[type="password"]:focus,
		form select:focus,
		form textarea:focus {
			background: #f8f8f8;
		}

	form input[type="text"],
	form input[type="email"]
	input[type="password"] {
		line-height: 16px;
	}

	form select {
		line-height: 16px;
	}

	form textarea {
		min-height: 128px;
	}

	form ul.actions {
		margin-top: 0;
	}

	form ::-webkit-input-placeholder {
		color: #555 !important;
		font-style: italic;
		line-height: 1.35em;
	}

	form :-moz-placeholder {
		color: #555 !important;
		font-style: italic;
	}

	form ::-moz-placeholder {
		color: #555 !important;
		font-style: italic;
	}

	form :-ms-input-placeholder {
		color: #555 !important;
		font-style: italic;
	}

	form ::-moz-focus-inner {
		border: 0;
	}

/* Image */

	.image {
		display: inline-block;
	}

		.image img {
			display: block;
			width: 100%;
		}

		.image.fit {
			display: block;
			width: 100%;
		}

		.image.left {
			float: left;
			margin: 0 32px 2em 0;
		}

		.image.centered {
			display: block;
			margin: 0 0 32px 0;
		}

			.image.centered img {
				margin: 0 auto;
				width: auto;
			}

		.image.featured {
			display: block;
			width: 100%;
			margin: 0 0 32px 0;
		}

/* Button */

	input[type="button"],
	input[type="submit"],
	input[type="reset"],
	button,
	.button {
		-moz-transition: all .25s ease-in-out;
		-webkit-transition: all .25s ease-in-out;
		-ms-transition: all .25s ease-in-out;
		transition: all .25s ease-in-out;
		display: inline-block;
		background: #444;
		text-align: center;
		text-transform: uppercase;
		font-weight: bold;
		text-decoration: none;
		border-radius: 0.35em;
		border: 0;
		outline: 0;
		cursor: pointer;
		padding: 0 8px;
		font-size: 1.4em;
		min-width: 12em;
		height: 48px;
		line-height: 48px;
	}

		input[type="button"]:hover,
		input[type="submit"]:hover,
		input[type="reset"]:hover,
		button:hover,
		.button:hover {
			background-color: #f98780;
		}

		input[type="button"].large,
		input[type="submit"].large,
		input[type="reset"].large,
		button.large,
		.button.large {
			font-size: 19px;
			min-width: 128px;
		}

		input[type="button"].style1,
		input[type="submit"].style1,
		input[type="reset"].style1,
		button.style1,
		.button.style1 {
			background: #e97770 url("../images/overlay.png");
			color: #fff;
		}

			input[type="button"].style1:hover,
			input[type="submit"].style1:hover,
			input[type="reset"].style1:hover,
			button.style1:hover,
			.button.style1:hover {
				background-color: #f98780;
			}

			input[type="button"].style1:active,
			input[type="submit"].style1:active,
			input[type="reset"].style1:active,
			button.style1:active,
			.button.style1:active {
				background-color: #d96760;
			}

		input[type="button"].style2,
		input[type="submit"].style2,
		input[type="reset"].style2,
		button.style2,
		.button.style2 {
			background: none;
			color: #606167;
			box-shadow: inset 0px 0px 2px 0px #a0a1a7;
		}

			input[type="button"].style2:hover,
			input[type="submit"].style2:hover,
			input[type="reset"].style2:hover,
			button.style2:hover,
			.button.style2:hover {
				box-shadow: inset 0px 0px 2px 0px #606167;
			}

			input[type="button"].style2:active,
			input[type="submit"].style2:active,
			input[type="reset"].style2:active,
			button.style2:active,
			.button.style2:active {
				box-shadow: inset 0px 0px 2px 0px #202127;
			}

		input[type="button"].style3,
		input[type="submit"].style3,
		input[type="reset"].style3,
		button.style3,
		.button.style3 {
			background: #ffe08f url("../images/overlay.png");
			color: #302682 !important;
		}

			input[type="button"].style3:hover,
			input[type="submit"].style3:hover,
			input[type="reset"].style3:hover,
			button.style3:hover,
			.button.style3:hover {
				background-color: #ff3d79;
			}

			input[type="button"].style3:active,
			input[type="submit"].style3:active,
			input[type="reset"].style3:active,
			button.style3:active,
			.button.style3:active {
				background-color: #1f232b;
			}

/* List */

	ul {
		list-style: disc;
		padding-left: 16px;
	}

		ul li {
			padding-left: 8px;
			font-size: 1em;
			line-height: 1.75em;
		}

		ul.style2 {
			list-style: none;
			padding-left: 0;
		}

			ul.style2 li {
				border-top: solid 1px #eee;
				padding: 24px 0 0 0;
				margin: 24px 0 0 0;
			}

				ul.style2 li:first-child {
					border-top: 0;
					padding-top: 0;
					margin-top: 0;
				}

		ul.style3 {
			list-style: none;
			padding-left: 0;
		}

			ul.style3 li {
				border-top: solid 1px #eee;
				padding: 8px 0 0 0;
				margin: 8px 0 0 0;
			}

				ul.style3 li:first-child {
					border-top: 0;
					padding-top: 0;
					margin-top: 0;
				}

	ol {
		list-style: decimal;
		padding-left: 20px;
	}

		ol li {
			padding-left: 4px;
		}

/* Actions */

	ul.actions {
		list-style: none;
		padding-left: 0;
		margin: 48px 0 0 0;
	}

		ul.actions li {
			display: inline-block;
			margin: 0 12px 0 12px;
			padding-left: 0;
		}

			ul.actions li:first-child {
				margin-left: 0;
			}

			ul.actions li:last-child {
				margin-right: 0;
			}

		ul.actions.special {
			text-align: center;
		}

/* Feature List */

	.feature-list {
		margin-left: auto;
		margin-right: auto;
		position: relative;
		top: 0;
	}

		.feature-list section {
			border-top: solid 1px #eee;
			padding-top: 48px;
			position: relative;
		}

		@media screen and (min-width: 981px) {

			/* COMMENTED OUT - nth-child not recommended */
			/* .feature-list > .row > :nth-child(-n + 2) > section {
				border-top: 0;
				padding-top: 30px;
			} */

		}

		.feature-list h3 {
			color: #ff3d79 !important;
			margin: 0 0 16px 0;
			font-size: 1.4em;
			letter-spacing: 0.03em;
			text-align: center;
			font-weight: 700;
			line-height: 1em;
		}

			.feature-list h3:before {
				display: block;
				color: #fff;
				background: #2f333b url("../images/overlay.png");
				border-radius: 40px;
				text-align: center;
				width: 40px;
				height: 40px;
				line-height: 40px;
				margin-right: 12px;
				position: absolute;
				left: 0;
				margin-top: -0.5em;
			}
			
section#features div.feature-list div.row div.col-12-medium section p {
	color: #5a5d65;
	text-align: center;
	line-height: 1.7;
	font-size: 1.1em;
}

		.feature-list.small section {
			padding-left: 56px;
		}

		.feature-list.small h3:before {
			font-size: 13px;
		}

/* Icons */

	.icon {
		text-decoration: none;
		text-decoration: none;
	}

		.icon:before {
			-moz-osx-font-smoothing: grayscale;
			-webkit-font-smoothing: antialiased;
			display: inline-block;
			font-style: normal;
			font-variant: normal;
			text-rendering: auto;
			line-height: 1;
			text-transform: none !important;
			font-family: 'Font Awesome 5 Free';
			font-weight: 400;
		}

		.icon:before {
			line-height: inherit;
			font-size: 20px;
		}

		.icon > .label {
			display: none;
		}

		.icon.solid:before {
			font-weight: 900;
		}

		.icon.brands:before {
			font-family: 'Font Awesome 5 Brands';
		}

/* Box */

	.box header {
		margin: 0 0 24px 0;
	}

		.box header.style1 {
			position: relative;
			margin: -0.5em 0 0 0;
			padding-top: 0;
		}

	.box h2 {
		margin: 0 0 12px 0;
		font-size: 18px;
		letter-spacing: 0.05em;
	}

	.box h3 {
		margin: 0 0 8px 0;
		font-size: 16px;
		font-weight: 600;
		letter-spacing: 0.05em;
	}

	.post{
		padding-top:50px !important;
	}

	.box.post-excerpt .image.left {
		position: relative;
		top: 8px;
		width: 80px;
	}

	.box.post-excerpt h3, .box.post-excerpt p {
		margin-left: 112px;
	}

/* Wrapper */

	.wrapper {
		position: relative;
		padding: 96px 0 48px 0;
	}

		.wrapper .title {
			position: absolute;
			top: 0;
			left: 50%;
			text-align: center;
			text-transform: uppercase;
			display: block;
			font-weight: 700;
			letter-spacing: 4px;
			font-size: 16px;
			width: 20em;
			height: 52px;
			top: -2.7em;
			line-height: 52px;
			margin-bottom: -3.25em;
			margin-left: -10em;
			padding-top: 8px;
		}

			.wrapper .title:before {
				content: '';
				position: absolute;
				bottom: -38px;
				left: -35px;
				width: 35px;
				height: 38px;
				background: url("../images/shadow.png");
			}

			.wrapper .title:after {
				-moz-transform: scaleX(-1);
				-webkit-transform: scaleX(-1);
				-ms-transform: scaleX(-1);
				transform: scaleX(-1);
				content: '';
				position: absolute;
				bottom: -38px;
				right: -35px;
				width: 35px;
				height: 38px;
				background: url("../images/shadow.png");
			}

		.wrapper.style1 {
			background: #302682 url("../images/overlay.png");
			color: #ffe08f;
			color: rgba(255, 255, 255, 0.75);
		}

			.wrapper.style1 .title {
				background: #302682  url("../images/overlay.png");
				color: #ffe08f;
			}

			.wrapper.style1 h1, .wrapper.style1 h2, .wrapper.style1 h3, .wrapper.style1 h4, .wrapper.style1 h5, .wrapper.style1 h6, .wrapper.style1 strong, .wrapper.style1 b, .wrapper.style1 a {
				color: #fff;
			}

		.wrapper.style1 #logo p {
			color: #fff;
		}

		.wrapper.style1 #logo p .purplecol {
			color: #ffe08f;
		}

		.wrapper.style1 #logo p a {
			color: #ffe08f;
			text-decoration: none;
		}

		.wrapper.style1 #logo p a:hover {
			color: #fff;
			text-decoration: none;
		}


		.wrapper.style2 {
			background: #fff;
		}

			.wrapper.style2 .title {
				background: #fff;
				color: #2e294f;
			}

		.wrapper.style3 {
			background: #f3f3f3 url("../images/overlay.png");
		}

			.wrapper.style3 .title {
				background: #f3f3f3 url("../images/overlay.png");
				color: #484d55;
			}

			.wrapper.style3 .image {
				border: solid 10px #fff;
			}

.wrapper.style-fullwidth {
    background: #f8f9fa;
    padding: 96px 0 48px 0;
}

#understandgw,
#understandsourcesgw,
#understandopticalgw {
    padding-top: 60px;
}

#understandgw,
#understandsourcesgw {
    padding-bottom: 0;
}

    .wrapper.style-fullwidth .title {
        background: #f8f9fa;
        color: #2e294f;
    }

    /* Special handling for header elements in fullwidth sections */
    .wrapper.style-fullwidth header {
        text-align: center;
        padding: 0 0 32px 0;
        margin-bottom: 32px;
    }

    .wrapper.style-fullwidth header h2 {
        color: #302682 !important;
        font-size: 26px !important;
        font-weight: 700 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.1em !important;
        margin-bottom: 0 !important;
        line-height: 1.4;
    }

    .wrapper.style-fullwidth header h2:last-of-type {
        margin-bottom: 0;
    }

    /* Support for underlined text in headers */
    .wrapper.style-fullwidth header h2 u {
        color: #ff3d79;
        text-decoration-color: #ff3d79;
        text-decoration-thickness: 2px;
        text-underline-offset: 3px;
    }

    @media screen and (max-width: 980px) {
        .wrapper.style-fullwidth header h2 {
            font-size: 1.5em;
        }
    }

    @media screen and (max-width: 736px) {
        .wrapper.style-fullwidth header h2 {
            font-size: 20px;
            letter-spacing: 0.05em;
        }
    }

/* Page Wrapper */

	#page-wrapper > section {
		margin-bottom: 0;
	}

/* Header */

	#header {
		position: relative;
		min-height: auto;
		height: auto;
		padding: 80px 20px 60px;
		background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
		overflow: hidden;
	}

		#header:before {
			content: '';
			position: absolute;
			top: 0;
			left: 0;
			width: 100%;
			height: 100%;
			background: url("../images/overlay.png");
		}

		.homepage #header {
			min-height: 768px;
		}

/* Logo */

	#logo {
		width: 100%;
		text-align: center;
		position: relative;
		top: 24px;
		padding-bottom: 48px;
	}

		#logo h1 {
			font-weight: 900;
			text-transform: uppercase;
			color: #fff;
			font-size: 26px;
			letter-spacing: 4px;
		}

		#logo p {
			color: #2e294f;
			text-transform: uppercase;
			margin: 20px 0 0 0;
			display: block;
			font-size: 26px;

		}
		
		#logo p .purplecol{
		color:#302682;
		}

/* Nav with Logo (for non-homepage pages) */

	#nav.nav-with-logo {
		display: flex;
		align-items: center;
		justify-content: center;
	}

	#nav.nav-with-logo > ul {
		gap: 40px;
	}

	.nav-logo {
		display: flex;
		align-items: center;
		margin-right: 40px;
	}

	.nav-logo img {
		height: 40px;
		width: auto;
		display: block;
	}

/* Tagline Banner (below nav on non-homepage) */

	#tagline-banner {
		background-color: #302682;
		padding: 15px 20px;
		text-align: center;
		margin-top: 66px; /* Height of nav bar */
		margin-bottom: 60px;
	}

	#tagline-banner p {
		color: #ffffff;
		text-transform: uppercase;
		font-family: 'rift-soft';
		font-size: 1.1em;
		margin: 0;
		line-height: 1.3;
	}

	#tagline-banner p .purplecol {
		color: #ffe08f;
	}

/* Nav with Logo - Mobile */
	@media screen and (max-width: 980px) {
		#nav.nav-with-logo > ul {
			gap: 20px;
		}

		.nav-logo {
			margin-right: 20px;
		}

		.nav-logo img {
			height: 35px;
		}
	}

	@media screen and (max-width: 736px) {
		#tagline-banner {
			display: none;
		}

		#nav.nav-with-logo > ul {
			gap: 12px;
		}

		.nav-logo {
			margin-right: 12px;
		}

		.nav-logo img {
			height: 28px;
		}
	}

/* Nav */

	#nav {
		position: fixed;
		display: block;
		top: 0;
		left: 0;
		width: 100%;
		text-align: center;
		z-index: 10000;
		background-color: #302682;
		padding: 10px 0;
	}

		#nav > ul {
			display: flex;
			justify-content: center;
			gap: 40px;
			padding: 0;
			margin: 0;
			list-style: none;
		}

			#nav > ul > li {
				display: inline-block;
				padding: 0;
				margin: 0;
			}

				#nav > ul > li > ul {
					display: none;
				}

				#nav > ul > li > a, #nav > ul > li > span {
    display: block;
    color: #fff;
    font-weight: 700;
    font-size: 1em;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.1em;
    transition: all 0.3s ease;
    padding: 12px 0;
}

				#nav > ul > li:hover > a {
					color: #ffe08f;
				}

				#nav > ul > li.active > a, #nav > ul > li.active > span {
					color: #ffe08f;
				}

				#nav > ul > li > a.active {
					color: #ffe08f;
				}

	.dropotron {
		background: #222835 url("../images/overlay.png");
		background-color: rgba(44, 50, 63, 0.925);
		padding: 20px 16px 20px 16px;
		border-radius: 0.35em;
		box-shadow: inset 0px 0px 1px 1px rgba(255, 255, 255, 0.25);
		min-width: 12em;
		text-align: left;
		margin-top: -1.25em;
		margin-left: -1px;
		list-style: none;
	}

		.dropotron.level-0 {
			margin-top: -1px;
			margin-left: 0;
			border-top-left-radius: 0;
			border-top-right-radius: 0;
		}

		.dropotron a, .dropotron span {
			-moz-transition: all .25s ease-in-out;
			-webkit-transition: all .25s ease-in-out;
			-ms-transition: all .25s ease-in-out;
			transition: all .25s ease-in-out;
			display: block;
			color: #eee;
			color: rgba(255, 255, 255, 0.75);
			text-transform: uppercase;
			text-decoration: none;
			font-size: 0.7em;
			letter-spacing: 4px;
			border-top: solid 1px rgba(255, 255, 255, 0.15);
			line-height: 48px;
		}

		.dropotron li {
			padding-left: 0;
		}

			.dropotron li:first-child a, .dropotron li:first-child span {
				border-top: 0;
			}

			.dropotron li:hover > a, .dropotron li:hover > span {
				color: #fff;
			}

/* Intro */

	#intro {
		padding-bottom: 128px;
		text-align: center;
		color:#ffe08f;
	}

		#intro p.style1 {
			font-size: 1.35em;
			letter-spacing: 0.075em;
			line-height: 1.6em;
			color: #fff;
		}

		#intro p.style2 {
			font-weight: 700;
			color: #ffe08f;
			border-radius: 12px;
			border: 2px solid #ffe08f;
			font-size: 26px;
			letter-spacing: 0.05em;
			line-height: 1.4;
			padding: 24px;
			margin-bottom: 24px;
			max-width: 900px;
			margin-left: auto;
			margin-right: auto;
			box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
			background: rgba(255, 255, 255, 0.05);
		}

			#intro p.style2 a {
				color: inherit;
				text-decoration: none;
			}

		#intro p.style3 {
			font-size: 20px;
			width: auto;
			margin: 0 auto 24px;
			color: rgba(255, 255, 255, 0.9);
			line-height: 1.6;
		}
		
		#intro p.style3 strong,#intro p.style3 a{
			color:#ffe08f;
		}

/* Features */

	#features header.style1 {
		padding-bottom: 80px;
	}

	#features ul.actions {
		margin-top: 80px;
	}

/* Highlights */

	#highlights .highlight {
		text-align: center;
	}

		#highlights .highlight h3 {
			color: #e97770;
			margin: 0 0 12px 0;
			font-size: 18px;
			letter-spacing: 0.05em;
		}

/* Main */

/* Footer */

	#footer {
		background: #302682 url("../images/overlay.png");
		color: #eee;
		color: rgba(255, 255, 255, 0.5);
margin-bottom:0;
	}

		#footer h1, #footer h2, #footer h3, #footer h4, #footer h5, #footer h6, #footer strong, #footer b, #footer a {
			color: #fff;
		}

		#footer hr {
			border-top-color: #333;
			border-top-color: rgba(255, 255, 255, 0.05);
		}

		#footer form input[type="text"],
		#footer form input[type="email"],
		#footer form input[type="password"],
		#footer form select,
		#footer form textarea {
			background: #ccc;
			box-shadow: none;
		}

			#footer form input[type="text"]:focus,
			#footer form input[type="email"]:focus,
			#footer form input[type="password"]:focus,
			#footer form select:focus,
			#footer form textarea:focus {
				background: #fff;
			}

		#footer input[type="button"],
		#footer input[type="submit"],
		#footer input[type="reset"],
		#footer button,
		#footer .button {
			color: #fff;
			box-shadow: inset 0px 0px 2px 0px rgba(255, 255, 255, 0.5);
		}

			#footer input[type="button"]:hover,
			#footer input[type="submit"]:hover,
			#footer input[type="reset"]:hover,
			#footer button:hover,
			#footer .button:hover {
				color: #fff;
				box-shadow: inset 0px 0px 2px 0px rgba(255, 255, 255, 0.65);
			}

			#footer input[type="button"]:active,
			#footer input[type="submit"]:active,
			#footer input[type="reset"]:active,
			#footer button:active,
			#footer .button:active {
				box-shadow: inset 0px 0px 2px 0px rgba(255, 255, 255, 0.75);
			}

			#footer input[type="button"].style2:active,
			#footer input[type="submit"].style2:active,
			#footer input[type="reset"].style2:active,
			#footer button.style2:active,
			#footer .button.style2:active {
				box-shadow: inset 0px 0px 2px 0px rgba(255, 255, 255, 0.75);
			}

		#footer .title {
			background: #282b34 url("../images/overlay.png");
			color: #eee;
		}

		#footer header.style1 {
			padding-bottom: 96px;
			margin-bottom: 96px;
			border-bottom: solid 1px rgba(255, 255, 255, 0.05);
		}

			#footer header.style1 h2 {
				color: #fff;
			}

			#footer header.style1 .p {
				color: inherit;
			}

		#footer .feature-list {
			max-width: 100%;
		}

			#footer .feature-list section {
				border-top-color: rgba(255, 255, 255, 0.05);
			}

			#footer .feature-list h3:before {
				background: #3d4249 url("../images/overlay.png");
			}

/* Copyright */

	#copyright {
		text-align: center;
		padding-top: 96px;
		margin-top: 0px;
		border-top: solid 1px rgba(255, 255, 255, 0.05);
	}

		#copyright ul {
			display: inline-block;
			border-radius: 0.35em;
			box-shadow: inset 0px 0px 1px 1px rgba(255, 255, 255, 0.05);
			color: #ffe08f;
			padding: 12px 32px;
			font-size: 0.9em;
		}

			#copyright ul li {
				display: inline-block;
				margin-left: 16px;
				padding-left: 16px;
				border-left: solid 1px #333;
				border-left-color: rgba(255, 255, 255, 0.05);
			}

				#copyright ul li:first-child {
					border-left: 0;
					margin-left: 0;
					padding-left: 0;
				}

		#copyright a {
			color: inherit;
		}

			#copyright a:hover {
				color: #fff;
			}

/* XLarge */

	@media screen and (max-width: 1680px) {

		/* Basic */

			body, input, textarea, select {
				font-size: 17px;
			}

	}

/* Large */

	@media screen and (max-width: 1280px) {

		/* Basic */

			body, input, select, textarea {
				font-size: 18px;
				line-height: 1.6;
				letter-spacing: 0.015em;
			}

		/* Wrapper */

			.wrapper {
				padding: 64px 0 112px 0;
			}

		/* Logo */

			#logo {
				margin-top: -0.5em !important;
			}

				#logo h1 {
					font-size: 1.75em;
				}

		/* Intro */

			#intro {
				padding-bottom: 112px;
			}

				#intro p.style1 {
					font-size: 20px;
				}

				#intro p.style2 {
					font-size: 2.25em;
				}

		/* Footer */

			#footer {
				padding-bottom: 64px;
			}

				#footer header.style1 {
					padding-bottom: 64px;
					margin-bottom: 64px;
					border-bottom: solid 1px rgba(255, 255, 255, 0.05);
				}

		/* Copyright */

			#copyright {
				padding-top: 64px;
				margin-top: 64px;
			}

	}

/* Medium */

	#navPanel, #titleBar {
		display: none;
	}

	@media screen and (max-width: 980px) {

		/* Section/Article */

			header br {
				display: none;
			}

		/* Form */

			form ul.actions {
				text-align: center;
			}

		/* Feature List */

			.feature-list {
				max-width: 40em;
			}

				.feature-list section {
					padding: 30px !important;
				}

				.feature-list > .row > :first-child > section {
					border-top: 0;
					padding-top: 0;
				}

		/* Nav */

			#nav {
				display: none;
			}

		/* Logo */

			#logo {
				top: 0;
			}

		/* Intro */

			#intro p.style3 {
				width: auto;
			}

		/* Highlights */

			#highlights .highlight {
				max-width: 40em;
				margin-left: auto;
				margin-right: auto;
			}

		/* Footer */

			#footer .feature-list {
				border-top: solid 1px rgba(255, 255, 255, 0.05);
				padding-top: 64px;
			}

			#features2 .button.neon-gradient {

  font-size: 14px !important;
  padding: 18px 25px !important;

}

	}

		@media screen and (max-width: 980px) and (min-width: 737px) {

				/* COMMENTED OUT - nth-child not recommended */
				/* #footer .feature-list > .row > :nth-child(2) > section {
					border-top: 0;
					padding-top: 0;
				} */

		}

	@media screen and (max-width: 980px) {

		/* Nav */

			#page-wrapper {
				-moz-backface-visibility: hidden;
				-webkit-backface-visibility: hidden;
				-ms-backface-visibility: hidden;
				backface-visibility: hidden;
				-moz-transition: -moz-transform 0.5s ease;
				-webkit-transition: -webkit-transform 0.5s ease;
				-ms-transition: -ms-transform 0.5s ease;
				transition: transform 0.5s ease;
				padding-bottom: 1px;
			}

			#titleBar {
				-moz-backface-visibility: hidden;
				-webkit-backface-visibility: hidden;
				-ms-backface-visibility: hidden;
				backface-visibility: hidden;
				-moz-transition: -moz-transform 0.5s ease;
				-webkit-transition: -webkit-transform 0.5s ease;
				-ms-transition: -ms-transform 0.5s ease;
				transition: transform 0.5s ease;
				display: block;
				height: 44px;
				left: 0;
				position: fixed;
				top: 0;
				width: 100%;
				z-index: 10001;
				background: none;
			}

				#titleBar .title {
					display: none;
				}

				#titleBar .toggle {
					text-decoration: none;
					position: absolute;
					top: 0;
					left: 0;
					width: 60px;
					height: 44px;
				}

					#titleBar .toggle:before {
						-moz-osx-font-smoothing: grayscale;
						-webkit-font-smoothing: antialiased;
						display: inline-block;
						font-style: normal;
						font-variant: normal;
						text-rendering: auto;
						line-height: 1;
						text-transform: none !important;
						font-family: 'Font Awesome 5 Free';
						font-weight: 900;
					}

					#titleBar .toggle:before {
						-moz-transition: all .15s ease-in-out;
						-webkit-transition: all .15s ease-in-out;
						-ms-transition: all .15s ease-in-out;
						transition: all .15s ease-in-out;
						text-decoration: none;
						content: '\f0c9';
						font-size: 14px;
						position: absolute;
						top: 6px;
						left: 6px;
						display: block;
						width: 54px;
						height: 38px;
						line-height: 38px;
						text-align: center;
						color: rgba(255, 255, 255, 0.75);
						background-color: #302682 ;
						border-radius: 4px;
					}

					#titleBar .toggle:active:before {
						background-color: rgba(92, 95, 103, 0.75);
					}

			#navPanel {
				-moz-backface-visibility: hidden;
				-webkit-backface-visibility: hidden;
				-ms-backface-visibility: hidden;
				backface-visibility: hidden;
				-moz-transform: translateX(-275px);
				-webkit-transform: translateX(-275px);
				-ms-transform: translateX(-275px);
				transform: translateX(-275px);
				-moz-transition: -moz-transform 0.5s ease;
				-webkit-transition: -webkit-transform 0.5s ease;
				-ms-transition: -ms-transform 0.5s ease;
				transition: transform 0.5s ease;
				display: block;
				height: 100%;
				left: 0;
				overflow-y: auto;
				position: fixed;
				top: 0;
				width: 275px;
				z-index: 10002;
				background-color: #302682 ;
				box-shadow: inset -3px 0px 4px 0px rgba(0, 0, 0, 0.1);
			}

				#navPanel .link {
					display: block;
					color: rgba(255, 255, 255, 0.5);
					text-transform: uppercase;
					text-decoration: none;
					font-size: 0.85em;
					letter-spacing: 0.15em;
					text-decoration: none;
					height: 44px;
					line-height: 44px;
					border-top: solid 1px rgba(255, 255, 255, 0.05);
					margin: 0 15px 0 15px;
				}

					#navPanel .link:first-child {
						border-top: 0;
					}

				#navPanel .indent-1 {
					display: inline-block;
					width: 16px;
				}

				#navPanel .indent-2 {
					display: inline-block;
					width: 32px;
				}

				#navPanel .indent-3 {
					display: inline-block;
					width: 48px;
				}

				#navPanel .indent-4 {
					display: inline-block;
					width: 64px;
				}

				#navPanel .indent-5 {
					display: inline-block;
					width: 80px;
				}

				#navPanel .depth-0 {
					color: #fff;
				}

			body.navPanel-visible #page-wrapper {
				-moz-transform: translateX(275px);
				-webkit-transform: translateX(275px);
				-ms-transform: translateX(275px);
				transform: translateX(275px);
			}

			body.navPanel-visible #titleBar {
				-moz-transform: translateX(275px);
				-webkit-transform: translateX(275px);
				-ms-transform: translateX(275px);
				transform: translateX(275px);
			}

			body.navPanel-visible #navPanel {
				-moz-transform: translateX(0);
				-webkit-transform: translateX(0);
				-ms-transform: translateX(0);
				transform: translateX(0);
			}

	}

/* Small */

	@media screen and (max-width: 736px) {

		.feature-list section.card-top-border ul, section.card-top-border ul{
			margin-left: 0 !important;
		}

		/* Basic */

			body, input, select, textarea {
				line-height: 24px;
				font-size: 20px;
				letter-spacing: 0;
			}

			h1 {
				font-size: 1.6em;
				letter-spacing: 0.05em;
				margin: 0 0 16px 0;
				line-height: 1.2em;
			}

			h2, h3, h4, h5, h6 {
				font-size: 19px;
				letter-spacing: 0.05em;
				margin: 0 0 16px 0;
				line-height: 1em;
			}

			hr {
				margin: 16px 0 16px 0;
			}

		/* Section/Article */

			section, article {
				clear: both;
			}

			header br {
				display: none;
			}

			header.style1 {
				padding: 0 0 16px 0;
			}

				header.style1 h2 {
					font-size: 24px;
					letter-spacing: 0.075em;
					line-height: 20px;
				}

				header.style1 p {
					font-size: 16px;
					letter-spacing: 0;
					display: block;
					margin: 0;
				}

		/* Button */

			input[type="button"],
			input[type="submit"],
			input[type="reset"],
			button,
			.button {
				display: block;
				width: 100%;
				font-size: 16px;
				max-width: 30em;
				margin: 0 auto;
			}

		/* Actions */

			ul.actions {
				margin: 32px 0 0 0;
			}

				ul.actions li {
					margin: 15px 0 0 0;
					display: block;
				}

					ul.actions li:first-child {
						margin-top: 0;
					}

		/* Feature List */

			.feature-list section {
				padding: 30px !important;
		
			}

			.feature-list h3:before {
				font-size: 0.9em;
			}

		/* Box */

			.box.post-excerpt .image.left {
				position: relative;
				top: 4px;
				width: 25%;
				margin: 0;
			}

			.box.post-excerpt h3, .box.post-excerpt p {
				margin-left: 32.5%;
			}

		/* Wrapper */

			.wrapper {
				padding: 48px 0 96px 0;
			}

				.wrapper .title {
					font-size: 0.9em;
					width: 18em;
					height: 40px;
					top: -2.2em;
					line-height: 40px;
					margin-bottom: -2.5em;
					margin-left: -9em;
					padding-top: 8px;
				}

					.wrapper .title:before, .wrapper .title:after {
						height: 15px;
						bottom: -15px;
						background-size: 100% 100%;
					}

		/* Header */

			#header {
				height: 272px;
			}

				.homepage #header {
					height: 450px;
					min-height: 450px;
				}

		/* Logo */

			#logo {
				text-align: center;
				padding-left: 32px;
				padding-right: 32px;
			}
			
			#logo h1 a img{
			width: 55%;
				}

				#logo h1 {
					font-size: 1.7em;
					letter-spacing: 3px;
				}

				#logo p {
					margin: 20px 0 0 0;
					display: block;
					letter-spacing: 3px;
					font-weight:1em;
					line-height: 1.5em;
				}

				#logo p .smaller {
margin-top:20px;
				}

		/* Intro */

			#intro {
				text-align: center;
				padding-right: 32px;
				padding-left: 32px;
				padding-bottom: 80px;
				margin: 0 auto;
			}

				#intro p.style1 {
					margin-bottom: 24px;
				}

				#intro p.style2 {
					font-size: 24px;
					letter-spacing: 0.05em;
					line-height: 30px;
					padding: 20px;
				}

		/* Features */

			#features header.style1 {
				padding-bottom: 64px;
			}

			#features ul.actions {
				margin-top: 64px;
			}

		/* Content */

			#content {
				padding: 0 0 32px 0;
			}

				#content header.style1 {
					padding-bottom: 40px;
				}

		/* Footer */

			#footer {
				padding-bottom: 0;
			}

				#footer header.style1 {
					padding-bottom: 0;
					margin-bottom: 32px;
					border-bottom: 0;
				}

				#footer .feature-list {
					border-top: 0;
					padding-top: 0;
				}

		/* Copyright */

			#copyright {
				padding-top: 0;
				margin-top: 64px;
				border-top: 0;
			}

				#copyright ul {
					padding: 16px 32px;
					width: 100%;
				}

					#copyright ul li {
						display: block;
						margin: 8px 0 0 0;
						border-left: 0;
						padding: 0;
					}

						#copyright ul li:first-child {
							margin-top: 0;
						}


									#features2 .button.neon-gradient {

  font-size: 13px !important;
  padding: 10px 25px !important;

}

	}

	
/* Create a custom checkbox */
/*
.checkmark {
	position: relative;
	top: 0;
	left: 0;
	height: 25px;
	width: 25px;
	background-color: #eee;
  }
  */
  input[type=checkbox] + label {
	display: block;
	margin: 3px;
	cursor: pointer;
	padding: 3px;
  }
  
  input[type=checkbox] {
	display: none;
  }
  
  input[type=checkbox] + label:before {
	content: "\2714";
	border: 0;
background: #eee;
box-shadow: inset 0px 0px 1px 0px #a0a1a7;
border-radius: 0.35em;
	border-radius: 3px;
	display: inline-block;
	width: 30px;
	height: 30px;
	padding: 0;
	margin-right: 3px;
	vertical-align: middle;
	color: transparent;
	transition: .2s;
	float:left;
	text-align: center;
	line-height: 30px;
  }
  
  input[type=checkbox] + label:active:before {
	transform: scale(0);
  }
  
  input[type=checkbox]:checked + label:before {
	background-color: #302682;

	color: #fff;
  }
  
  input[type=checkbox]:disabled + label:before {
	transform: scale(1);
	border-color: #aaa;
  }
  
  input[type=checkbox]:checked:disabled + label:before {
	transform: scale(1);
	background-color: #302682;
	border-color: grey;
  }

  .form-error-icon,.form-error-message{
	  color: red !important;
  }

  .terms{
	  color:#312783;
	  margin-left:10px;
  }

  .termscontent
  {
	  text-align: left;
  }
  
  .petitfooter{
	  margin-top: 0px;
	  width: 100%;
	  display: flex;
	  justify-content: center;
	  align-items: center;
	  padding: 32px 0 74px;
  background: #fff;
  }
  .petitfooter .col-12-medium {
	  width: 100%;
  }
  .petitfooter p {
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 24px;
	max-width: 100%;
  }
  .petitfooter img{
	max-height : 65px;
	height : 65px;
	width: auto;
	display: inline-block;
	vertical-align: middle;
}

/* Responsive footer logos for small screens */
@media screen and (max-width: 736px) {
	.petitfooter p {
		gap: 16px;
	}
	.petitfooter img {
		max-height: 50px;
		height: 50px;
	}
}

/* ===================================
   NEW HOMEPAGE STYLES (2026)
   =================================== */

/* ===================================
   ENHANCED BUTTON STYLES
   =================================== */

/* Button Style: Neon Gradient with Yellow Border */
.button.neon-gradient,
input[type="button"].neon-gradient,
input[type="submit"].neon-gradient {
  background: linear-gradient(135deg, #302682 0%, #5040b8 100%);
  color: white;
  border-radius: 50px;
  border: 2px solid #ffe08f;
  box-shadow: 0 0 20px rgba(255, 224, 143, 0.5), 0 0 40px rgba(255, 224, 143, 0.3), inset 0 0 20px rgba(255, 224, 143, 0.1), 0 8px 25px rgba(48, 38, 130, 0.4);
  font-weight: 700;
  position: relative;
  overflow: hidden;
}

.button.neon-gradient:hover,
input[type="button"].neon-gradient:hover,
input[type="submit"].neon-gradient:hover {
  transform: translateY(-3px);
  border-color: #ffd970;
  box-shadow: 0 0 30px rgba(255, 224, 143, 0.8), 0 0 60px rgba(255, 224, 143, 0.5), inset 0 0 30px rgba(255, 224, 143, 0.2), 0 12px 35px rgba(48, 38, 130, 0.5);
  text-shadow: 0 0 10px rgba(255, 224, 143, 0.8);
}

.button.neon-gradient::before {
	content: '';
	position: absolute;
	inset: -2px;
	border-radius: 50px;
	background: linear-gradient(45deg, #ffe08f, #ffd970, #ffe08f);
	z-index: -1;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.button.neon-gradient:hover::before {
	opacity: 0.3;
}

/* Adjust Register now button text size and padding */
#intro .button.neon-gradient {
	font-size: 20px;
	padding: 0 24px;
	min-width: 10em;
}



/* ===================================
   ENHANCED CARD STYLES
   =================================== */

/* Card with Gradient Border */
.feature-list section.card-gradient-border,
section.card-gradient-border {
	background: white;
	position: relative;
	border-radius: 16px;
	padding: 48px 32px 32px 32px !important;
}

.feature-list section.card-gradient-border::before,
section.card-gradient-border::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 16px;
	padding: 3px;
	background: linear-gradient(135deg, #302682, #ff3d79, #ffe08f);
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

.feature-list section.card-gradient-border:hover,
section.card-gradient-border:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 40px rgba(48, 38, 130, 0.2);
}

.feature-list section.card-gradient-border h3,
section.card-gradient-border h3 {
	color: #302682 !important;
	position: relative;
	z-index: 1;
}

.feature-list section.card-gradient-border p,
section.card-gradient-border p {
	position: relative;
	z-index: 1;
	font-size:1.1em;
	line-height: 1.8;
}

.text-left-list li {
color: #302682;
  text-decoration: none;
  transition: color 0.3s ease;
  font-weight: 500;
  font-size: 17px;
  text-align: left;
}

  .text-left-list li a{
  color: #302682;
  text-decoration: none;
  transition: color 0.3s ease;
  font-weight: 500;
  font-size: 17px;
}

.text-left-list li a:hover {
  color: #ff3d79;
  text-decoration: underline;
}



/* Card with Top Border - For text-heavy educational content */
.feature-list section.card-top-border,
section.card-top-border {
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border-top: 5px solid #ff3d79;
    padding: 30px;
}

.feature-list section.card-top-border:hover,
section.card-top-border:hover {
    border-top-color: #302682;
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.feature-list section.card-top-border h3,
section.card-top-border h3 {
    color: #302682 !important;
}

.feature-list section.card-top-border p,
section.card-top-border p {
    margin-bottom: 16px;
    line-height: 1.8;
    color: #302682;
	font-size:1.1em;
}

.feature-list section.card-top-border ul,
section.card-top-border ul {
    list-style: disc;
    margin-left: 32px;
    margin-bottom: 16px;
}

section.card-top-border ul.actions {
    list-style: none;
    margin-left: 0;
}

.feature-list section.card-top-border ul li,
section.card-top-border ul li {
    margin-bottom: 13px;
    padding-left: 8px;
    line-height: 1.6;
    text-align: left;
}

.feature-list section.card-top-border ul li a,ul li a,
section.card-top-border ul li a {
    color: #302682;
    text-decoration: none;
    transition: color 0.3s ease;
    font-weight: 500;
	font-size:1em;
}

.feature-list section.card-top-border ul li a:hover,
section.card-top-border ul li a:hover {
    color: #ff3d79;
    text-decoration: underline;
}


/* Card with Image Layout */
.feature-list section.card-with-image,
section.card-with-image {
	display: flex;
	align-items: center;
	gap: 40px;
	padding: 56px 40px 40px 40px !important;
}

.feature-list section.card-with-image .card-content,
section.card-with-image .card-content {
	flex: 1;
	text-align: left;
}

.feature-list section.card-with-image .card-image,
section.card-with-image .card-image {
	flex: 0 0 40%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.feature-list section.card-with-image .card-image img,
section.card-with-image .card-image img {
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.feature-list section.card-with-image h3,
section.card-with-image h3 {
	text-align: left !important;
}

.feature-list section.card-with-image p,
section.card-with-image p {
	text-align: left !important;
}

/* Image caption/credit */
.card-image-caption {
	display: block;
	margin-top: 10px;
	font-size: 18px;
	color: #888;
	font-style: italic;
	text-align: center;
}

/* Responsive - stack on mobile */
@media screen and (max-width: 768px) {
	.feature-list section.card-with-image,
	section.card-with-image {
		flex-direction: column;
	}

	.feature-list section.card-with-image .card-image,
	section.card-with-image .card-image {
		flex: 0 0 auto;
		width: 100%;
	}
}

/* ===================================
   SOCIAL MEDIA FLOATING SIDEBAR
   =================================== */

.social-float-sidebar {
    position: fixed;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.social-float-item {
    position: relative;
    width: 55px;
    height: 55px;
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    border: 3px solid #ffe08f;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffe08f;
    transition: all 0.4s ease;
    box-shadow: 0 4px 20px rgba(255, 224, 143, 0.3),
                inset 0 0 20px rgba(255, 224, 143, 0.1);
    cursor: pointer;
    text-decoration: none;
}

.social-float-item:hover {
    transform: translateX(-15px) scale(1.15);
    background: linear-gradient(135deg, #ff3d79 0%, #302682 100%);
    border-color: #ff3d79;
    color: white;
    box-shadow: 0 8px 30px rgba(255, 61, 121, 0.5),
                0 0 40px rgba(255, 224, 143, 0.4);
}

.social-float-item svg {
    width: 26px;
    height: 26px;
    fill: currentColor;
    transition: all 0.3s ease;
}

/* Tooltip on hover */
.social-float-item span {
    position: absolute;
    right: 70px;
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    color: white;
    padding: 10px 18px;
    border-radius: 8px;
    font-size: 0.95em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s ease;
    box-shadow: 0 6px 20px rgba(48, 38, 130, 0.3);
}

.social-float-item span::after {
    content: '';
    position: absolute;
    right: -10px;
    top: 50%;
    transform: translateY(-50%);
    border-left: 10px solid #302682;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
}

.social-float-item:hover span {
    opacity: 1;
    right: 75px;
}

/* COMMENTED OUT - nth-child not recommended */
/* Specific color overrides for each platform */
 .social-float-item:nth-child(1):hover {
    Slack
    background: linear-gradient(135deg, #4A154B 0%, #611f69 100%);
}

.social-float-item:nth-child(2):hover {
    Instagram
    background: linear-gradient(135deg, #E1306C 0%, #C13584 50%, #833AB4 100%);
}

.social-float-item:nth-child(3):hover {
    X/Twitter
    background: linear-gradient(135deg, #000000 0%, #14171A 100%);
}

.social-float-item:nth-child(4):hover {
    Facebook
    background: linear-gradient(135deg, #1877F2 0%, #0c63d4 100%);
}

.social-float-item:nth-child(5):hover {
    YouTube
    background: linear-gradient(135deg, #FF0000 0%, #CC0000 100%);
}

.social-float-item:nth-child(6):hover {
    LinkedIn
    background: linear-gradient(135deg, #0A66C2 0%, #004182 100%);
}

.social-float-item:nth-child(7):hover {
    Email
    background: linear-gradient(135deg, #ff3d79 0%, #ff6b99 100%);
} 

/* Hide social sidebar on mobile */
@media screen and (max-width: 768px) {
    .social-float-sidebar {
        display: none;
    }
}

/* ===================================
   VIDEO STYLING
   =================================== */

.image.featured video {
	width: 1000px;
	height: auto;
	max-width: 100%;
	border-radius: 8px;
	display: block;
	margin: 0 auto;
}

/* ===================================
   ADDITIONAL TYPOGRAPHY
   =================================== */

.purplecol {
	color: #302682;
	font-weight: 600;
}

#intro em {
	font-style: italic;
	color: #ff3d79;
}

.smaller {
	font-size: 0.9em;
}

/* ===================================
   MORE INFO SECTION STYLING
   =================================== */

#More {
	margin-top: 0;
}

#More .container {
	max-width: 1400px;
}

#features2 .col-12-medium {
	width: 100%;
	max-width: none;
}

#features2 .col-12-medium > section {
	background: white;
	border-radius: 24px;
	padding: 64px 80px;
	box-shadow: 0 4px 20px rgba(48, 38, 130, 0.1);
	text-align: center;
	
	max-width: 1200px;
	margin: 0 auto;
	margin-bottom: 40px;
}

/* Adjust h2 size */
#features2 h2 {
	font-size: 1.8em !important;
	margin-bottom: 32px !important;
	font-weight: 600;
	text-align: left !important;
	line-height: 1em;
}

/* Make buttons larger and side by side */
#features2 .actions {
	display: flex;
	justify-content: flex-start;
	gap: 32px;
	flex-wrap: wrap;
}

#features2 .actions li {
	display: inline-block;
}

#features2 .button.neon-gradient {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	padding: 18px 45px;
	text-transform: uppercase;
	font-weight: 700;
	letter-spacing: 0.05em;
	white-space: nowrap;
	line-height: 1.2;
}

/* page how it works */

#how-it-works{
	padding-bottom: 100px !important;
}



/* ===================================
   ABOUT US PAGE STYLING
   =================================== */

/* Section Header */
.section-header {
	text-align: center;
	margin-bottom: 48px;
}

.section-header h2 {
	font-size: 32px;
	font-weight: 700;
	margin-bottom: 8px;
	line-height: 1em;
}

.section-header p {
	font-size: 16px;
}

/* Colors based on wrapper context */
.wrapper.style1 .section-header h2 {
	color: #fff !important;
}

.wrapper.style1 .section-header p {
	color: #ffe08f !important;
}

.wrapper.style2 .section-header h2 {
	color: #302682 !important;
}

.wrapper.style2 .section-header p {
	color: #5a5d65 !important;
}

.wrapper.style2 .section-header strong {
	color: #5a5d65 !important;
}

/* Team Grid */
.team-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 32px;
	margin-top: 32px;
}

.team-member {
	background: white;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	transition: all 0.3s ease;
	border-top: 4px solid #302682;
}

.team-member:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(48, 38, 130, 0.15);
}

.team-member h4 {
	color: #302682 !important;
	font-size: 20px;
	margin-bottom: 8px;
	font-weight: 700;
}

.team-member .position {
	display: inline-block;
	background: #302682;
	color: #ffe08f !important;
	font-weight: 600;
	font-size: 16px;
	padding: 8px 24px;
	margin-bottom: 16px;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: 25px;
}

.team-member .bio {
	color: #5a5d65 !important;
	line-height: 1.6;
	font-size: 16px;
}

/* Contributors Grid */
.contributor-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 32px;
	margin-top: 32px;
}

.contributor-card {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	cursor: pointer;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.contributor-card:hover {
	transform: scale(1.05);
	box-shadow: 0 8px 25px rgba(48, 38, 130, 0.2);
}

.contributor-image,
.contributor-telescope {
	width: 100%;
	height: 250px;
	object-fit: cover;
	display: block;
	transition: opacity 0.3s ease;
}

.contributor-telescope {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
}

.contributor-card:hover .contributor-image {
	opacity: 0;
}

.contributor-card:hover .contributor-telescope {
	opacity: 1;
}

.contributor-name {
	background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
	color: white;
	padding: 16px;
	text-align: center;
	font-weight: 600;
	font-size: 18px;
}

/* Network Statistics */
.stats-container {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 32px;
	margin-top: 32px;
}

.stat-box {
	background: linear-gradient(135deg, rgba(48, 38, 130, 0.05) 0%, rgba(255, 224, 143, 0.1) 100%);
	border-radius: 16px;
	padding: 32px;
	text-align: center;
	border: 2px solid #ffe08f;
	transition: all 0.3s ease;
}

.stat-box:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(255, 224, 143, 0.3);
	border-color: #ff3d79;
}

.stat-number {
	font-size: 40px;
	font-weight: 700;
	margin-bottom: 5px;
	line-height: 1;
}

.stat-label {
	font-size: 18px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Stat colors based on wrapper context */
.wrapper.style1 .stat-number {
	color: #fff !important;
}

.wrapper.style1 .stat-label {
	color: #ffe08f !important;
}

.wrapper.style2 .stat-number {
	color: #302682 !important;
}

.wrapper.style2 .stat-label {
	color: #5a5d65 !important;
}

/* Equipment Section */
.equipment-section {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 32px;
	margin-top: 32px;
}

.equipment-card {
	background: white;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	transition: all 0.3s ease;
	border-left: 4px solid #302682;
}

.equipment-card:hover {
	transform: translateX(5px);
	box-shadow: 0 6px 20px rgba(48, 38, 130, 0.15);
	border-left-color: #ff3d79;
}

.equipment-card h4 {
	color: #302682 !important;
	font-size: 1.2em;
	margin-bottom: 16px;
	font-weight: 700;
	line-height: 1em;
}

.equipment-card ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.equipment-card ul li {
	color: #5a5d65 !important;
	padding: 8px 0;
	border-bottom: 1px solid rgba(48, 38, 130, 0.1);
	font-size: 16px;
	line-height: 1.6;
}

.equipment-card ul li:last-child {
	border-bottom: none;
}

.equipment-card ul li strong {
	color: #302682 !important;
	font-weight: 600;
}

/* Demographics Grid */
.demo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 32px;
	margin-top: 32px;
}

.demo-card {
	background: white;
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	transition: all 0.3s ease;
}

.demo-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(48, 38, 130, 0.15);
}

.demo-card h4 {
	color: #302682 !important;
	font-size: 1.3em;
	margin-bottom: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1em;
}

/* Bar Chart */
.bar-chart {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.bar-item {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.bar-label {
	display: flex;
	justify-content: space-between;
	color: #5a5d65 !important;
	font-weight: 600;
	font-size: 1.05em;
}

.bar-fill {
	height: 8px;
	background: linear-gradient(90deg, #302682 0%, #ff3d79 100%);
	border-radius: 4px;
	transition: all 0.3s ease;
}

.bar-item:hover .bar-fill {
	height: 12px;
	box-shadow: 0 2px 8px rgba(48, 38, 130, 0.3);
}

/* Map Container */
.map-container {
	margin-top: 32px;
	border-radius: 16px;
	overflow: hidden;
}

.map-placeholder {
	background: linear-gradient(135deg, rgba(48, 38, 130, 0.05) 0%, rgba(255, 224, 143, 0.1) 100%);
	border: 3px dashed #ffe08f;
	border-radius: 16px;
	padding: 19px 24px;
	text-align: center;
	min-height: 400px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.map-placeholder h3 {
	margin-bottom: 16px;
	font-size: 1.8em;
	font-weight: 700;
}

.map-placeholder p {
	max-width: 700px;
	margin: 0 auto;
	line-height: 1.7;
	font-size: 1.1em;
}

/* Map placeholder colors based on wrapper context */
.wrapper.style1 .map-placeholder {
	border: 3px dashed #ffe08f;
}

.wrapper.style1 .map-placeholder h3 {
	color: #fff !important;
}

.wrapper.style1 .map-placeholder p {
	color: #ffe08f !important;
}

.wrapper.style2 .map-placeholder {
	border: 3px dashed #ffe08f;
}

.wrapper.style2 .map-placeholder h3 {
	color: #302682 !important;
}

.wrapper.style2 .map-placeholder p {
	color: #5a5d65 !important;
}

/* Call to Action buttons - keep original neon-gradient effect with white text */
.wrapper.style1 .button.neon-gradient {
	padding: 30px 40px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	line-height: 1 !important;
}

.wrapper.style1 .button.neon-gradient:hover {
	color: white !important;
	text-decoration: none !important;
}

/* Responsive adjustments for About Us page */
@media screen and (max-width: 980px) {

	section#team-hero.wrapper.style1
	{
		padding-bottom: 10px !important;
	}


	.team-grid,
	.contributor-grid,
	.stats-container,
	.equipment-section,
	.demo-grid {
		grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	}

	.section-header h2 {
		font-size: 32px;
	}

	.stat-number {
		font-size: 40px;
	}
}

@media screen and (max-width: 736px) {
	.team-grid,
	.contributor-grid,
	.stats-container,
	.equipment-section,
	.demo-grid {
		grid-template-columns: 1fr;
	}

	.section-header h2 {
		font-size: 1.8em;
	}

	.map-placeholder {
		padding: 32px 16px;
		min-height: 300px;
	}
}

/* ============================================
   FAQ Page Styles
   ============================================ */

/* FAQ Intro */
.faq-intro {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 60px;
}

.faq-intro p {
    font-size: 19px;
    color: rgba(255, 255, 255, 0.95);
    line-height: 1.7;
}

/* FAQ Categories */
.faq-categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-bottom: 50px;
}

.category-card {
    background: rgba(255, 255, 255, 0.1);
    padding: 60px 25px;
    border-radius: 12px;
    text-align: center;
    border: 2px solid rgba(255, 224, 143, 0.3);
    transition: all 0.3s ease;
    cursor: pointer;
}

.category-card:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: #ffe08f;
    transform: translateY(-5px);
}

.category-card .icon {
    font-size: 40px;
    margin-bottom: 15px;
}

.category-card h3 {
    color: #ffe08f !important;
    font-size: 1.1em;
    margin: 0;
}

/* FAQ Section */
.faq-section {
    margin-bottom: 50px;
}

.faq-section-header {
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    padding: 45px 30px;
    border-radius: 12px;
    margin-bottom: 25px;
    box-shadow: 0 4px 15px rgba(48, 38, 130, 0.3);
}

.faq-section-header h2 {
    color: #ffe08f !important;
    font-size: 26px;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 15px;
	line-height: 1em;
}

.faq-section-header .icon {
    font-size: 24px;
}

/* FAQ Accordion */
.faq-item {
    background: white;
    border-radius: 12px;
    margin-bottom: 15px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

.faq-item:hover {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
}

.faq-question {
    padding: 20px 25px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    transition: all 0.3s ease;
    background: white;
}

.faq-question:hover {
    background: #f8f9fc;
}

.faq-question h4 {
    color: #302682 !important;
    font-size: 18px;
    margin: 0;
    flex: 1;
    line-height: 1.4;
}

.faq-toggle {
    font-size: 24px;
    color: #302682;
    transition: transform 0.3s ease;
    font-weight: bold;
    flex-shrink: 0;
}

.faq-item.active .faq-toggle {
    transform: rotate(45deg);
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    background: #f8f9fc;
}

.faq-item.active .faq-answer {
    max-height: 1000px;
    padding: 25px;
    border-top: 2px solid #e8e8ec;
}

.faq-answer p {
    color: #5a5d65;
    line-height: 1.8;
    margin-bottom: 15px;
}

.faq-answer p:last-child {
    margin-bottom: 0;
}

.faq-answer ul {
    margin: 15px 0;
    padding-left: 25px;
}

.faq-answer li {
    color: #5a5d65;
    line-height: 1.8;
    margin-bottom: 10px;
	font-size:1em;
}

.faq-answer a {
    color: #302682;
    font-weight: 600;
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
}

.faq-answer a:hover {
    color: #ff3d79;
    border-bottom-color: #ff3d79;
}

.faq-answer strong {
    color: #302682;
}

/* Highlight Box */
.highlight-box {
    background: linear-gradient(135deg, rgba(48, 38, 130, 0.05) 0%, rgba(255, 224, 143, 0.1) 100%);
    padding: 20px;
    border-radius: 10px;
    border-left: 4px solid #ffe08f;
    margin: 15px 0;
}

.highlight-box p {
    margin: 0;
    color: #302682 !important;
    font-weight: 600;
}

/* FAQ Search */
.faq-search {
    max-width: 600px;
    margin: 0 auto 50px;
}

.faq-search input {
    width: 100%;
    padding: 18px 25px;
    border: 3px solid #ffe08f;
    border-radius: 50px;
    font-size: 16px;
    background: white;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.faq-search input:focus {
    border-color: #302682;
    box-shadow: 0 6px 30px rgba(48, 38, 130, 0.2);
    outline: none;
}

/* Search Results */
.search-results {
    max-width: 800px;
    margin: 0 auto 40px;
    padding: 30px;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.search-results h3 {
    color: #302682 !important;
    font-size: 24px;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid #ffe08f;
}

#resultsList {
    list-style: none;
    padding: 0;
    margin: 0 0 20px 0;
}

#resultsList li {
    margin-bottom: 12px;
}

#resultsList li a {
    display: block;
    padding: 15px 20px;
    background: #f8f9fc;
    color: #302682;
    text-decoration: none;
    border-radius: 8px;
    border-left: 4px solid #ffe08f;
    transition: all 0.3s ease;
    font-size: 16px;
    font-weight: 500;
}

#resultsList li a:hover {
    background: #302682;
    color: #ffe08f;
    border-left-color: #ff3d79;
    transform: translateX(5px);
    box-shadow: 0 4px 15px rgba(48, 38, 130, 0.2);
}

.search-results .button {
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    color: #ffe08f;
    border: none;
    padding: 0px 30px;
    font-size: 16px;
    border-radius: 25px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: 600;
}

.search-results .button:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(48, 38, 130, 0.3);
    background: linear-gradient(135deg, #3d30a3 0%, #302682 100%);
}

/* FAQ CTA */
.faq-cta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    margin-top: 60px;
}

.cta-card {
    background: white;
    padding: 40px;
    border-radius: 15px;
    text-align: center;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    border-top: 5px solid #302682;
}

.cta-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(48, 38, 130, 0.2);
}

.cta-card .icon {
    font-size: 48px;
    margin-top: 10px;
    margin-bottom: 30px;
}

.cta-card h3 {
    color: #302682 !important;
    font-size: 1.5em;
    margin-bottom: 15px;
	line-height: 1em;
}

.cta-card p {
    color: #5a5d65;
    margin-bottom: 25px;
    line-height: 1.6;
}

.cta-card .button {
    padding: 12px 30px !important;
    display: inline-block !important;
    min-width: auto !important;
}

/* No Results */
.no-results {
    display: none;
    text-align: center;
    padding: 60px 20px;
    background: white;
    border-radius: 15px;
    margin: 40px 0;
}

.no-results.active {
    display: block;
}

.no-results h3 {
    color: #302682 !important;
    font-size: 26px;
    margin-bottom: 15px;
}

.no-results p {
    color: #5a5d65;
    font-size: 16px;
}

/* FAQ Responsive */
@media screen and (max-width: 980px) {
    .faq-categories {
        grid-template-columns: 1fr;
    }

    .faq-section-header h2 {
        font-size: 1.6em;
    }

    .faq-question h4 {
        font-size: 16px;
    }
}

@media screen and (max-width: 736px) {
    .faq-section-header {
        padding: 20px;
    }

    .faq-question {
        padding: 15px 20px;
    }

    .faq-item.active .faq-answer {
        padding: 20px;
    }

    .cta-card {
        padding: 30px;
    }
}

/* ========================================
   UTILITY CLASSES FOR PUBLIC PAGES
   ======================================== */

/* Text Alignment */
.text-center {
    text-align: center !important;
}

.text-left {
    text-align: left !important;
}

.text-right {
    text-align: right !important;
}

/* Colors */
.color-purple {
    color: #302682 !important;
}

.color-yellow {
    color: #ffe08f !important;
}

.color-dark-gray {
    color: #5a5d65 !important;
}

.color-white {
    color: white !important;
}

.color-light-white {
    color: rgba(255, 255, 255, 0.9) !important;
}

.color-rebeccapurple {
    color: rebeccapurple !important;
}

/* Font Sizes */
.fs-12 {
    font-size: 16px;
}

.fs-15 {
    font-size: 20px;
}

.fs-20 {
    font-size: 26px;
}

.fs-09 {
    font-size: 0.9em;
}

.fs-18 {
    font-size: 1.5em;
}

/* Font Weights */
.fw-700 {
    font-weight: 700;
}

.fw-bold {
    font-weight: bold;
}

/* Margins */
.mb-0 {
    margin-bottom: 0px !important;
}

.mb-05 {
    margin-bottom: 8px !important;
}

.mb-1 {
    margin-bottom: 16px !important;
}

.mb-15 {
    margin-bottom: 24px !important;
}

.mb-15em {
    margin-bottom: 24px !important;
}

.mb-2 {
    margin-bottom: 32px !important;
}

.mt-05 {
    margin-top: 8px !important;
}

.mt-1 {
    margin-top: 16px !important;
}

.mt-10px {
    margin-top: 10px !important;
}

.mt-15px {
    margin-top: 15px !important;
}

.mt-2 {
    margin-top: 32px !important;
}

.mt-20px {
    margin-top: 20px !important;
}

.mt-60 {
    margin-top: 60px !important;
}

.mb-20px {
    margin-bottom: 20px !important;
}

.mb-40px {
    margin-bottom: 40px !important;
}

.m-60-40 {
    margin: 60px 0 40px 0 !important;
}

/* Padding */
.p-3 {
    padding: 48px !important;
}

/* Display */
.block-center {
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Width Utilities */
.w-100 {
    max-width: 100% !important;
}

.w-75 {
    max-width: 75% !important;
}

.w-65 {
    max-width: 65% !important;
}

.w-55 {
    max-width: 55% !important;
}

@media screen and (max-width: 768px) {
    .w-75, .w-65, .w-55 {
        max-width: 95% !important;
    }
}

/* Image/Video Utilities */
.img-center {
    margin: 0 auto !important;
    display: block !important;
}

.mt-2em {
    margin-top: 32px !important;
}

/* Text Transform */
.uppercase {
    text-transform: uppercase !important;
}

/* Letter Spacing */
.ls-01 {
    letter-spacing: 0.1em !important;
}

/* Font Style */
.italic {
    font-style: italic !important;
}

/* Section Headers for Act Pages */
.act-header {
    text-align: center;
    margin: 60px 0 40px 0;
}

.act-header h2 {
    color: #302682;
    font-size: 26px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.act-header p {
    color: #5a5d65;
    font-size: 16px;
    margin-top: 10px;
}

/* Hero Text Styles */
.hero-text-large {
    text-align: center;
    font-size: 1.1em;
    color: #ffe08f;
    margin-bottom: 16px;
}

.hero-text-large-mb0 {
    text-align: center;
    font-size: 1.1em;
    color: #ffe08f;
    margin-bottom: 0px;
}

/* CTA Gradient Box */
.cta-gradient-box {
    background: linear-gradient(135deg, rgba(48, 38, 130, 0.05) 0%, rgba(255, 224, 143, 0.1) 100%);
    border-top: 4px solid #ffe08f;
    padding: 48px;
    text-align: center;
}

.cta-gradient-box h3 {
    color: #ffe08f !important;
    font-size: 26px;
    margin-bottom: 8px;
}

.cta-gradient-box p {
    font-size: 16px;
    color: white;
    margin-bottom: 32px;
}

.bottom-cta{
	padding: 10px 0 80px 0;
}

/* Bar Chart Width Utilities */
.bar-width-3 { width: 3%; }
.bar-width-4 { width: 4%; }
.bar-width-6 { width: 6%; }
.bar-width-7 { width: 7%; }
.bar-width-8 { width: 8%; }
.bar-width-9 { width: 9%; }
.bar-width-11 { width: 11%; }
.bar-width-12 { width: 12%; }
.bar-width-18 { width: 18%; }
.bar-width-19 { width: 19%; }
.bar-width-21 { width: 21%; }
.bar-width-22 { width: 22%; }
.bar-width-23 { width: 23%; }
.bar-width-28 { width: 28%; }
.bar-width-32 { width: 32%; }
.bar-width-35 { width: 35%; }
.bar-width-38 { width: 38%; }
.bar-width-45 { width: 45%; }

/* Registration Form Styles */

.formregister, .formregister label{
color:#fff;
}

.form-section-header {
    color: #fff;
    margin-top: 32px;
    margin-bottom: 16px;
    font-size: 1.1em;
}

.alert-description {
    font-size: 0.9em;
    color: #fff;
}

.registration-alert-box {
    background: linear-gradient(135deg, rgba(48, 38, 130, 0.05) 0%, rgba(255, 224, 143, 0.1) 100%);
    border-top: 4px solid #ff00cd;
    margin-bottom: 48px;
    padding: 32px;
}

.registration-alert-box h3 {
    color: #302682;
    font-size: 1.5em;
    text-align: center;
    margin-bottom: 16px;
}

.registration-alert-text {
    font-size: 18px;
    text-align: center;
    line-height: 1.8;
	color:#302682;
}

.registration-alert-text strong{

	color:#302682 !important;
}

.registration-welcome-text {
    font-size: 1.1em;
    text-align: center;
    margin-top: 24px;
    margin-bottom: 8px;
}

.form-container-narrow {
    max-width: 700px;
}

.form-title-center {
    text-align: center;
    margin-bottom: 8px;
}

.form-subtitle {
    color: #fff;
    text-align: center;
    font-size: 18px;
    margin-bottom: 32px;
}

.form-info-text {
    color: #fff;
    text-align: center;
    margin-bottom: 32px;
}

.alert-danger {
    color: #d32f2f;
    background-color: #ffebee;
    padding: 16px;
    margin: 16px 0;
    border-radius: 4px;
}

.form-group-mt2 {
    margin-top: 32px;
}

.form-check-mb15 {
    margin-bottom: 24px;
}

.submit-button-center {
    text-align: center;
    margin-top: 40px;
}

/* ===================================
   BLOG STYLES
   =================================== */

/* Blog Grid Layout */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 30px;
    margin-bottom: 40px;
}

@media (max-width: 768px) {
    .blog-grid {
        grid-template-columns: 1fr;
    }
}

/* Blog Post Card */
.blog-post {
    position: relative;
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.featured-badge {
    position: absolute;
    top: 20px;
    left: -14px;
    background: #ff4d4f;
    color: #fff;
    padding: 12px 22px;
    border-radius: 8px;
    font-size: 18px;
    font-weight: 700;
    z-index: 2;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 12px rgba(255, 77, 79, 0.4);
}

.blog-post:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

/* Featured Post - Full Width */
.blog-post.featured {
    grid-column: 1 / -1;
    flex-direction: row;
    min-height: 350px;
}

@media (max-width: 768px) {
    .blog-post.featured {
        flex-direction: column;
    }
}

.blog-post.featured .post-image {
    width: 50%;
    height: auto;
    object-fit: cover;
}

@media (max-width: 768px) {
    .blog-post.featured > a {
        width: 100% !important;
        height: auto !important;
    }

    .blog-post.featured .post-image {
        width: 100%;
        height: 250px;
    }
}

.blog-post.featured .post-content {
    width: 50%;
}

@media (max-width: 768px) {
    .blog-post.featured .post-content {
        width: 100%;
    }
}

/* Post Image */
.post-image {
    width: 100%;
    height: 250px;
    object-fit: cover;
}

/* Post Content */
.post-content {
    padding: 25px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

/* Post Header */
.post-header h3 {
    color: #302682;
    font-size: 1.2em;
    margin: 10px 0;
    line-height: 1.3;
}

.post-header h3 a {
    color: #302682;
    text-decoration: none;
}

.post-header h3 a:hover {
    color: #ff3d79;
}

/* Blog Search & Filter Bar */
.blog-filter-bar {
    background: #fff;
    border-radius: 16px;
    padding: 28px 32px;
    margin-bottom: 60px;
    box-shadow: 0 4px 25px rgba(0, 0, 0, 0.1);
}

.blog-search-form {
    margin-bottom: 18px;
}

.blog-search-input {
    width: 100%;
    padding: 14px 22px;
    border: 2px solid #e0dde8;
    border-radius: 12px;
    font-size: 16px;
    background: #fff;
    color: #333;
    transition: all 0.3s ease;
}

.blog-search-input::placeholder {
    color: #aaa;
}

.blog-search-input:focus {
    border-color: #302682;
    outline: none;
    box-shadow: 0 0 10px rgba(48, 38, 130, 0.15);
}

.blog-category-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.blog-filter-btn {
    display: inline-block;
    padding: 8px 20px;
    border-radius: 12px;
    font-size: 0.9em;
    font-weight: 600;
    text-transform: uppercase;
    text-decoration: none;
    border: 2px solid #302682;
    color: #302682;
    background: transparent;
    transition: all 0.3s ease;
}

.blog-filter-btn:hover {
    background: #302682;
    color: #fff;
    text-decoration: none;
}

.blog-filter-btn.active {
    background: #302682;
    color: #fff;
}

/* Post Tags */
.post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

.tag-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 1em;
    font-weight: 600;
    text-transform: uppercase;
    background: #ffe08f;
    color: #302682;
    text-decoration: none;
    transition: all 0.3s ease;
}

.tag-badge:hover {
    background: #302682;
    color: #ffe08f;
    text-decoration: none;
}

/* Tag Colors */
.tag-observation {
    background: #302682;
    color: white;
}

.tag-science {
    background: #ff3d79;
    color: white;
}

.tag-event {
    background: #ffe08f;
    color: #302682;
}

.tag-announcement {
    background: #3d30a3;
    color: white;
}

.tag-success {
    background: linear-gradient(135deg, #ffd700 0%, #ffed4e 100%);
    color: #302682;
}

.tag-news {
    background: linear-gradient(135deg, #ff3d79 0%, #302682 100%);
    color: white;
}

.tag-tutorial {
    background: #28a745;
    color: white;
}

.tag-spotlight {
    background: #fd7e14;
    color: white;
}

.tag-alert {
    background: #dc3545;
    color: white;
}

/* Post Meta */
.post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    font-size: 0.9em;
    color: #666;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid #eee;
}

.post-meta span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

/* Post Excerpt */
.post-excerpt {
    color: #555;
    line-height: 1.6;
    margin-bottom: 20px;
    flex-grow: 1;
}

/* Read More Button */
.read-more {
    display: inline-block;
    padding: 10px 20px;
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    color: #ffe08f;
    text-decoration: none;
    border-radius: 12px;
    font-weight: 600;
    transition: all 0.3s ease;
    align-self: flex-start;
}

.read-more:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(48, 38, 130, 0.3);
    text-decoration: none;
    color: #ffe08f;
}

/* No Results Message */
.no-results {
    text-align: center;
    padding: 60px 20px;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.no-results h3 {
    color: #302682;
    font-size: 1.7em;
    margin-bottom: 15px;
}

.no-results p {
    color: #666;
    font-size: 0.95em;
}

/* Blog Navigation/Pagination */
.navigation {
    margin: 30px 0;
}

.navigation .pagination {
    display: flex;
    justify-content: center;
    gap: 10px;
}

/* Single Post Content Styling */
.blogpage .post-content {
    font-size: 1.05em;
    line-height: 1.8;
}

.post-meta--hero {
    font-size: 1em;
    color: rgba(255, 255, 255, 0.8);
}

.blog-header-desc {
    font-size: 1.1em;
    color: rgba(255, 255, 255, 0.95);
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.small-note {
    font-size: 13px;
    color: #666;
    font-style: italic;
}

/* Science page - Scroll Spy Sidebar */
.science-scrollspy {
    position: fixed;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 100;
    display: none;
}

.science-scrollspy-inner {
    background: rgba(48, 38, 130, 0.92);
    border-radius: 0 6px 6px 0;
    padding: 10px 12px;
    box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3);
    max-width: 160px;
}

.science-scrollspy-section {
    font-size: 11px;
    font-weight: 700;
    color: #ffe08f;
    margin-bottom: 6px;
    line-height: 1.3;
}

.science-scrollspy ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.science-scrollspy ul li {
    padding: 0;
    margin: 0;
    line-height: 1;
}

.science-scrollspy ul li a {
    display: block;
    padding: 3px 0;
    font-size: 10px;
    color: rgba(255, 255, 255, 0.5);
    text-decoration: none;
    transition: color 0.3s;
    line-height: 1.3;
}

.science-scrollspy ul li a:hover {
    color: rgba(255, 255, 255, 0.85);
}

.science-scrollspy ul li.active a {
    color: #fff;
    font-weight: 700;
}

@media screen and (min-width: 1281px) {
    .science-scrollspy {
        display: block;
    }
}

/* Science page - Table of Contents */
.science-toc {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    padding: 25px 30px;
    margin-top: 30px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.science-toc h3 {
    color: #fff;
    font-size: 1.2em;
    margin-bottom: 15px;
    text-align: center;
}

.science-toc ol {
    list-style: none;
    counter-reset: toc-counter;
    padding: 0;
    margin: 0;
}

.science-toc > ol > li {
    counter-increment: toc-counter;
    padding: 8px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 1em;
    line-height: 1.5;
}

.science-toc > ol > li:last-child {
    border-bottom: none;
}

.science-toc > ol > li::before {
    content: counter(toc-counter) ". ";
    color: #ffe08f;
    font-weight: 700;
}

.science-toc ol li a {
    color: #fff;
    text-decoration: none;
    transition: color 0.2s;
}

.science-toc ol li a:hover {
    color: #ffe08f;
}

.science-toc ol ul {
    list-style: none;
    padding: 4px 0 2px 20px;
    margin: 0;
}

.science-toc ol ul li {
    padding: 3px 0;
    font-size: 0.9em;
    border-bottom: none;
    line-height: 1.4;
}

.science-toc ol ul li::before {
    content: "- ";
    color: rgba(255, 224, 143, 0.6);
}

.science-toc ol ul li a {
    color: rgba(255, 255, 255, 0.75);
}

.post-content h1,
.post-content h2,
.post-content h3,
.post-content h4 {
    color: #302682;
    margin-top: 30px;
    margin-bottom: 15px;
}

.post-content p {
    margin-bottom: 20px;
}

.post-content img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 20px 0;
}

.post-content ul,
.post-content ol {
    margin: 20px 0;
    padding-left: 30px;
}

.post-content ul li,
.post-content ol li {
    margin-bottom: 10px;
}

.post-content blockquote {
    border-left: 4px solid #ffe08f;
    padding-left: 20px;
    margin: 30px 0;
    font-style: italic;
    color: #555;
}

.post-content code {
    background: #f5f5f5;
    padding: 2px 6px;
    border-radius: 4px;
    font-family: monospace;
    font-size: 0.9em;
}

.post-content pre {
    background: #f5f5f5;
    padding: 20px;
    border-radius: 8px;
    overflow-x: auto;
    margin: 20px 0;
}

.post-content pre code {
    background: none;
    padding: 0;
}

/* Responsive Adjustments */
@media (max-width: 600px) {
    .post-content {
        padding: 15px;
    }

    .post-header h3 {
        font-size: 1.2em;
    }

    .post-meta {
        font-size: 0.8em;
        gap: 10px;
    }

    .tag-badge {
        font-size: 0.75em;
        padding: 3px 10px;
    }
}

/* Blog Page Title */
.blog-page-title {
    text-align: center;
    font-size: 2em;
    color: rgba(255, 255, 255, 0.95);
    margin-bottom: 0.5em;
    line-height: 1.4;
    font-weight: bold;
}

/* Blog Page Wrapper */
.blog-header {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
}

.blogpage {
    padding-top: 60px !important;
}

/* Blog Listing Section */
.blog-listing {
    padding-top: 50px !important;
}

/* Article Spacing */
article {
    margin: 0 0 60px 0;
}

/* Archive Section */
.archive-section {
    background: white;
    border-radius: 12px;
    padding: 30px;
    margin-top: 40px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.archive-section h3 {
    color: #302682;
    font-size: 1.5em;
    margin-bottom: 20px;
    border-bottom: 3px solid #ffe08f;
    padding-bottom: 10px;
}

.archive-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.archive-list li {
    margin-bottom: 10px;
    padding: 12px 15px;
    background: #f8f9fa;
    border-radius: 8px;
    transition: all 0.3s ease;
    border-left: 4px solid transparent;
}

.archive-list li:hover {
    background: #e9ecef;
    border-left-color: #ff3d79;
    transform: translateX(5px);
}

.archive-list li.active {
    background: #302682;
    border-left-color: #ffe08f;
}

.archive-list li a {
    color: #302682;
    text-decoration: none;
    font-weight: 500;
    font-size: 1.05em;
    display: block;
}

.archive-list li:hover a {
    color: #ff3d79;
}

.archive-list li.active a {
    color: #ffe08f;
}

@media (max-width: 768px) {
    .archive-section {
        padding: 20px;
        margin-top: 30px;
    }

    .archive-section h3 {
        font-size: 1.5em;
    }

    .archive-list li {
        padding: 10px;
    }

    .archive-list li a {
        font-size: 0.95em;
    }
}

/* Blog Pagination Styles */
.navigation {
    text-align: center;
    margin: 40px 0 20px 0;
}

.navigation .pagination {
    display: inline-flex;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}

.navigation .pagination li {
    margin: 0;
}

.navigation .pagination li a,
.navigation .pagination li span {
    display: inline-block;
    padding: 12px 18px;
    background: white;
    border: 2px solid #302682;
    border-radius: 8px;
    color: #302682;
    text-decoration: none;
    font-weight: 600;
    font-size: 1em;
    transition: all 0.3s ease;
    min-width: 45px;
    text-align: center;
}

.navigation .pagination li a:hover {
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    color: #ffe08f;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(48, 38, 130, 0.3);
}

.navigation .pagination li.active span {
    background: linear-gradient(135deg, #302682 0%, #3d30a3 100%);
    color: #ffe08f;
    border-color: #302682;
    box-shadow: 0 4px 12px rgba(48, 38, 130, 0.4);
}

.navigation .pagination li.disabled span {
    background: #f8f9fa;
    color: #adb5bd;
    border-color: #dee2e6;
    cursor: not-allowed;
    opacity: 0.6;
}

.navigation .pagination li.disabled a {
    background: #f8f9fa;
    color: #adb5bd;
    border-color: #dee2e6;
    cursor: not-allowed;
    opacity: 0.6;
    pointer-events: none;
}

/* Previous/Next buttons special styling */
.navigation .pagination li:first-child a,
.navigation .pagination li:last-child a {
    font-weight: 700;
    padding: 12px 24px;
}

.navigation .pagination li:first-child a:hover,
.navigation .pagination li:last-child a:hover {
    background: #ffe08f;
    color: #302682;
    border-color: #ffe08f;
}

/* Mobile responsive */
@media (max-width: 768px) {
    .navigation .pagination {
        gap: 5px;
    }

    .navigation .pagination li a,
    .navigation .pagination li span {
        padding: 10px 14px;
        font-size: 0.9em;
        min-width: 40px;
    }

    .navigation .pagination li:first-child a,
    .navigation .pagination li:last-child a {
        padding: 10px 18px;
    }
}

@media (max-width: 480px) {
    .navigation .pagination {
        gap: 3px;
    }

    .navigation .pagination li a,
    .navigation .pagination li span {
        padding: 8px 12px;
        font-size: 0.85em;
        min-width: 35px;
    }

    .navigation .pagination li:first-child a,
    .navigation .pagination li:last-child a {
        padding: 8px 14px;
    }
}

/* ===================================
   LIGHTBOX
   =================================== */

.lightbox-ready {
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.lightbox-ready:hover {
    opacity: 0.85;
}

.lightbox-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 99999;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

.lightbox-overlay.active {
    display: flex;
}

.lightbox-overlay img {
    max-width: 90vw;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 4px;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.5);
    cursor: default;
}

.lightbox-close,
.lightbox-close:hover {
    position: absolute;
    top: 20px;
    right: 30px;
    color: white;
    font-size: 40px;
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
    z-index: 100000;
    background: none;
    border: none;
    padding: 0;
}

@media screen and (max-width: 768px) {
    .lightbox-overlay img {
        max-width: 95vw;
        max-height: 85vh;
    }

    .lightbox-close {
        top: 15px;
        right: 20px;
        font-size: 36px;
    }

    .iframe-scroll-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .iframe-scroll-wrapper iframe {
        width: 900px !important;
        min-width: 900px;
    }

    .alerts-chart-wrapper {
        flex-direction: column;
    }
}

@media screen and (max-width: 736px) {
    #footer {
        padding-bottom: 30px;
    }
}
