@charset "utf-8";
/* CSS Document */

/* reset */
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, 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;
}

html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
	height: 100%;
	min-height: 100%;
}

body {
	background-color: #fff;
	font-family: Arial, Helvetica, sans-serif;
	color: #000;
	min-height: 100%;
	height: 100%;
}

/* images scale with browser window size */
img {
    max-width: 100%;
    height: auto;
    width: auto\9; /* ie8 */
}

p {margin: 1em 0;}

h1, h2, h3, h4 {
color: #233e90;
font-weight: bold;
margin: 1.5em 0 .5em 0;
}

h2 {font-size: 1.2em;}
h3 {font-size: 1em;}

li {margin-left: 2.5em;
line-height: 1.4em;
}

strong {font-weight: bold;}

/* alert */
.alert-msg{font-size:.75em;font-weight:bold;width:auto;position:relative;padding:15px 50px;text-align:center;}
.alert-msg a{font-weight:bold;color:#333}
.high{background-color:#f2dede;border-bottom:2px solid #ebccd1;color:#661615}
.high a{color:#661615}
.medium{background-color:#f4e1cd;border-bottom:2px solid #deb988;color:#452e12}
.medium a{color:#452e12}
.low{background-color:#d9edf7;border-bottom:2px solid #bce8f1;color:#0d3f7d}
.low a{color:#0d3f7d}
.alert-plus{font-size:1em}

/* add to elements so that they clear following elements at certain browser sizes */
.clearfix:before {
	display: table;
    content: " ";
}

.clearfix:after {
	display: table;
    content: " ";
	clear: both;
}

#page {
	width: 100%;
	margin: 0;
	position: relative;
	height: 100%;
	min-height: 100%;
}

/* ========================================
    the hamburger menu for mobile devices
    ====================================== */
#hamburger {
	display: none; 
    cursor: pointer;
    float: left;
	margin: .5em 0;
	z-index: 6;
	position: absolute;
	left: .5em;
	top: 46%;
}

#hamburger p {
    color: #fff;
	font-weight: bold;
	padding: 7px 8px 5px 8px;
	display: block;
	border: 1px solid rgba(255,255,255,.5);
}


/* =================================
   header - PSWP logo, tag, nav
==================================== */

#header {
    background-color: #f1f1f1;
	width: 100%;
	min-height: 47px;
	display: block;
	position: relative;
	box-sizing: border-box;
	top: 3px\9; /* IE8 and below */
}

#header img.top-logo {
	width: 45%;
	padding: 1.2em;
	margin-left: 1em;
}

#tag-line {
  max-width: 22%;
  position: absolute;
  right: 0;
  top: 7%;
  padding-right: 1em;
}

#tag-line img {
float: left;
width: 40%;
}

#tag-line p {
	font-family: 'Asap Condensed', sans-serif;
	font-weight: 600;
	color: #233e90;
	font-size: 1em; /* for non-JS browsers, else fittext.js */
	position: relative;
	left: -.6em;
	margin-top: .6em;
}


.ie9 #header {
	top: 2px;
}

nav {
 background-color: #233e90;
 width: 100%;
 box-sizing: border-box;
 font-size: 1.2em; /* for non-JS browsers, else fittext.js */
 font-weight: bold;
 margin: 0;
 padding: 0;
}

nav ul {
	display: flex;
    flex-direction: row;
    list-style-type: none;
    padding: 0;
    margin: 0 0 0 1.2em;
}

nav ul li {
	display: inline;
	margin: 0;
}

nav ul li a {
	color: #fff;
	text-decoration: none;
	display: block;
	padding: 1em 1.2em;
}

nav ul li a:hover,
nav ul li a:focus,
nav ul li a.active {
	background: rgba(0,0,0,.3);
}



/* =================================
   banner image and GOER, PEF logos 
==================================== */

#banner {
	width: 100%;
	display: block;
	position: relative;
	padding: 0;
	box-sizing: border-box;
	margin-bottom: 2em;
}

h1.page-title {
     font-family: 'Asap Condensed', sans-serif;
     font-weight: 600;
     font-size: 2.3em;
     background: #d78400;
     padding: .5em 1.5em;
     color: #fff;
     margin: 0;
     position: relative;
    word-spacing: 4px;
}
 
/* =================================
page content below banner 
==================================== */

#content {
	width: 100%;
	max-width: 1024px;
	margin: 0 auto;
	padding: 1em 2em 2em 2em;
	background-color: #fff;
	box-sizing: border-box;
}

#content p {
line-height: 1.5em;
}


.center {text-align:center;}


.no-wrap {white-space: nowrap}

.float-right {
float: right;
margin: 1em 0 .7em .7em;
clear: left;
}

.float-left {
float: left;
margin: 1em .7em .7em 0;
clear: right;
}

.ten {width: 10% !important;}
.twenty {width: 20% !important;}
.thirty {width: 30% !important;}
.fourty {width: 40% !important;}
.fifty {width: 50% !important;}
.sixty {width: 60% !important;}
.seventy {width: 70% !important;}
.eighty {width: 80% !important;}

/* ========================
	   Jump-to boxes 
	========================= */
	   
.jump-to {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	clear: both;
	box-sizing: border-box;
	justify-content: center;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
	
.jump-to article {
	border: 1px solid #d5820d;
	width: 22%;
	margin: 0 1.5%;
	position: relative;
	margin-bottom: 2em;
	overflow: hidden;
	padding-bottom: .3em;
}
.jump-to article.last {margin-right:0;}	

.jump-to article h1 {
	font-family: 'Asap Condensed', sans-serif;
	font-weight: 600;
	color: #fff;
	background-color: #d5820d;
	background-image:url(../../images/jump-to-arrow.png);
	background-repeat: no-repeat;
	background-position: right 50%;
	padding: .5em;
	font-size: 1.2em; /* for non-JS browsers, else fittext.js */
	margin: 0;
	text-transform: uppercase;
    word-spacing: 4px;
}

.jump-to article  a {
 text-decoration: none;
}

.jump-to article a:hover h1 {
 background-color: #d75600;
}

.jump-to article p {
	padding: 0 .5em;
	font-size: .9em;
	color: #000;
	line-height: 1.3em;
}

/* ========================
	   foundation courses  
	========================= */
	   
.fdn-courses {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	clear: both;
	box-sizing: border-box;
	justify-content: center;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
	
.fdn-courses article {
	border: 1px solid #d5820d;
	width: 100%;
	margin: 0 0 2em 0;
	position: relative;
	overflow: hidden;
	padding-bottom: .3em;
}

.fdn-courses article h3 {
	font-family: 'Asap Condensed', sans-serif;
	font-weight: 600;
	color: #fff;
	background-color: #d5820d;
	/* background-image:url(../../images/jump-to-arrow.png);
	background-repeat: no-repeat;
	background-position: right 50%;*/
	padding: .5em;
	font-size: 1.2em; /* for non-JS browsers, else fittext.js */
	margin: 0;
	text-transform: uppercase;
    word-spacing: 4px;
}

.fdn-courses article  a {
 text-decoration: none;
}

.fdn-courses article a:hover h3 {
 background-color: #d75600;
}

.fdn-courses article p, ul {
	margin: 1em;
	color: #000;
}

.fdn-courses article button {
    margin: 1em;
}

/* agency liasons table */


#liasons {
	width: 100%;
	border-bottom: 1px solid #ccc;
	border-left: 1px solid #ccc;
	padding: 0;
	box-sizing: border-box;
}

#liasons dt {
	background-color: #f1f1f1;
	font-weight: bold;
	border-top: 1px solid #ccc;
	border-right: 1px solid #ccc;
	padding: .5em .3em;
}

div.l-info {
    display: flex; /* to make row cells stack on mobile */ 
	flex-direction: row;
	flex-wrap: nowrap;
}

#liasons dd {
	padding: .3em .3em .7em .5em;
	margin: 0;
	width: 33%;
	max-width: 33%;
	word-wrap: break-word;
	overflow: hidden;
	border-right: 1px solid #ccc;
	display: inline-block;
}

#liasons dd span {
	display: none;
}


/* archive results */
.arch-result { 
	display: block;
	box-sizing: border-box;
	width: 100%;
	padding: .5em 0;
	border-top: 1px solid #ccc;
	
}
.error 			{ background:#F99; border:1px solid red; margin:1em 0; padding:1ex; }

.note {
  background-image: url(../../images/note-icon.png);
  background-repeat: no-repeat;
  background-color: #FFFCBF;
  background-position: 8px 8px;
  min-height: 44px;
  padding: .5em .8em .5em 38px;
  border: 1px solid #d78400;
  border-radius: 6px;
  color: #9D2301;
  display: inline-block;
  line-height: 1.4em !important;
  box-sizing: border-box;
}

.sidebar {
display: block;
background: #f1f1f1;
border: 1px solid #ccc;
padding: 0;
margin-top: 1em;
border-radius: 6px;
}

.sidebar h2 {
background: #ccc;
margin: 0;
padding: .3em;
color: #233e90;
}

.sidebar p {
padding: .1em 1.5em;
}

/* Style the form container */
.form-container {
  background-color: #f2f2f2;
  padding: 0 1em 1em 1em;
  border: 1px solid #ccc;
  margin-bottom: 1em;
}

.form-container h1, h2, h3, h4 {
 color: #000;
}

.form-row {
 display: block;
 width: 100%;
 border-bottom: 1px solid #ccc;
 padding-bottom: 1em;
}

.form-comment {
 font-size: .9em;
 margin-top:0;
}

/* Style inputs, select elements and textareas */
input[type=text], select, textarea{
  width: 100%;
  padding: .5em;
  border: 1px solid #ccc;
  box-sizing: border-box;
  resize: vertical;
  margin: .2em 0 .7em 0;
}

/* Style the label to display next to the inputs */
label {
 color: 000;
 margin-top: 1.5em;
 font-size: .9em;
}

label span {
color: #000;
font-weight: normal;
}

/* Style the submit button */
input[type=submit], button {
  background-color: #38803E;
  color: #fff;
  padding: 12px 20px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  margin: .5em 2em 0 0;
  font-weight: bold;
}

/* Style the cancel button */
input[type=reset] {
  background-color: #999;
  color: white;
  padding: 6px 10px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

.required {
color: red;
font-size: 1.2em;
}

.topper {
  background-color: #dedfe1;
  border-radius: 6px 6px 0 0;
  padding: .5em 1em;
  color: #233e90;
}

.course-item {
padding: 0 1em 1em 1em;
border-bottom: 1px solid #ccc;
}

.course-title {
font-weight: bold;
font-size: 1.2em;
margin-bottom: 0;
padding-bottom: 0;
}

.course-details {
display: block;
}

.course-details p {
font-weight: bold;
margin: 0;
padding: 0;
}

.course-details p span {
font-weight: normal;
}

.a-list {
text-decoration: none; 
padding-left: 1em;
margin-bottom: .5em;
display: block;
background-image: url(../../images/down-arrow.png);
background-repeat: no-repeat;
background-position: 0 50%;
color: #000;
}

.a-list:hover {
text-decoration: underline;
}

.top {
text-decoration: none;
padding-left: 1em;
display: block;
background-image: url(../../images/up-arrow.png);
background-repeat: no-repeat;
background-position: 0 50%;
color: #000;
text-transform: uppercase;
font-size: .8em;
position: relative;
left: 95%;
}

.req-button {
float: right;
position: relative;
margin: 1.4em 0 1.4em 1em;
padding: .4em .7em;
}
/* =================================
footer styles 
==================================== */
#footer {
	padding: 2% 5%;
	position: relative;
	display: block;
	clear: both;
	width: 100%;
	background: #f1f1f1;
	font-size: .9em;
	line-height: 1.2em;
	box-sizing: border-box;
	justify-content: center;
}

.col-1 {
	float: left;
	width: 28%;
	margin-right: 8%;
	padding-bottom: .5em;
}

.col-2 {
	float: left;
	width: 28%;
	margin-right: 8%;
	padding-bottom: .5em;
}

.col-3 {
	width: 28%;
	float: left;
	padding-bottom: .5em;
}

#footer h2 {
 font-weight: bold;
 color: #000;
 border-bottom: 1px solid #000;
 padding: 1em 0 .2em 0;
 margin-bottom: .5em;
}

#footer .h-rule {width:100%; border-bottom:1px solid #000; clear:both;}

	/* GOER FEF footer logos */
#logos {
    width: 100%;
	margin: 0 auto;
	max-width: 700px;
	padding: 0;
	clear: both;
	box-sizing: border-box;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
}

#logos a {
  padding: .5em 1em;
  display: inline-block;
  margin: 0 auto;
}

#logos img {
width: 100%;
}

.copyright {text-align:center; font-size:.8em;}

/* ==============================================
   tablet styles
   ============================================= */
 
 @media screen and (max-width: 1024px) {
 
    .jump-to article {
	width: 38%;
	margin: 0 3% 5% 3%;
	}
	
	#header img.top-logo {
	width: 55%;
	padding: 1.2em;
	margin-left: .5em;
}

#tag-line {
  max-width: 27%;
  position: absolute;
  right: -1em;
  top: 10%;
  padding-right: 1em;
}

#tag-line p {margin-top: .6em;}

#tag-line img {
float: left;
width: 42%;
}
	 
	#content {
	padding-left: 1%;
	width: 98%;
	padding-right: 1%;
	}
}  
 

/* mobile styles ======================================== */

@media screen and (max-width: 720px) {
	
 #header img.top-logo {
	width: 95%;
	padding: 1em 0 .5em 0;
 }

 #tag-line {
  position: relative;
  left: 0;
  bottom: 0;
  max-width: 100%;
  width: 100%;
  padding: 1% 3.5% 1.5% 3.5%;
  background-color: #233e90;
  margin: 0 0 1em 0;
  box-sizing: border-box;
  justify-content: center;
  z-index: 3;
}

#tag-line img {
float: left;
width: 17%;
margin-left: 4em;
}

#tag-line p {
	font-size: 1em; /* for non-JS browsers, else fittext.js */
	left: 0;
	color: #fff;
	margin: 1%;
	font-size: 75%;
 }	

#hamburger {
	display: block;
	}
	
nav {
	display: none; /* hide until toggled */
	position: absolute;
	top: 100%; /* position below header graphic */
	background-color: #233e90;
	z-index: 4;
	width: 100%;
	padding: 0;
	box-sizing:border-box;
	
	box-shadow: 0px 6px 9px rgba(0,0,0,.5) inset;
	}
	
nav ul {
    display: block;
    padding: 0;
    margin: 0;
	box-shadow: 0px 6px 9px rgba(0,0,0,.5);
}

nav ul li a {
	color: #fff;
	text-decoration: none;
	display: block;
	padding: 1.5em;
	width: 100%;
	border-top: 1px solid rgba(255, 255,255,.5);
}

nav ul li a:hover,
nav ul li a:focus{
	background: rgba(0,0,0,.3);
}

h1.page-title {
 position: relative;
 top: -4%;
 padding: .6em 0 .3em 0;
 z-index: 1;
 width: 100%;
 text-align: center;
 margin-bottom: -1.5em;
}
	
#content {
padding: 1em;
}

.jump-to article {
	width: 90%;
	margin: 0 0 5% 0;
	padding-bottom: 0;
    }
	
.jump-to article img {
	width: 100%;
}

.jump-to article p {
	font-size: 1.3em;
}

.float-right, .float-left {
float: none;
}

.ten, .twenty, .thirty, .fourty, .fifty, .sixty, .seventy, .eighty {width: 95% !important; }

/* agency liasons table */
div.l-info {
	flex-wrap: wrap;
	padding-bottom: .5em;
	border-right: 1px solid #ccc;
}

#liasons dd {
	width: 100%;
	max-width: 100%;
	padding-bottom: .1em;
	border-right: 0;
}

#liasons dd span {
	display: inline;
}

/* stack on mobile */
.course-details p span {
display: block;
margin-left: .7em;
}
	/* ========================
	   footer
	   ========================= */
	   
	.col-1, .col-2, .col-3 {
	float: none;
	width: 97%;
	margin-right: 1.5%;
	margin-left: 1.5%;
	padding-bottom: 2%;
	}
	
	#footer h2 {
	font-size: 1.3em;
	}
	
	#footer p {
	margin-top: .9em;
	font-size: 1.2em;
	line-height: 1.4em;
	}
	
	#footer p.copyright {font-size: .8em;}
	
/* GOER FEF footer logos */
#logos {
    width: 100%;
	margin: 0 auto;
	padding: 0;
	clear: both;
	box-sizing: border-box;
	justify-content: center;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

#logos a {
  padding: .5em 1em;
  width: 100%;
  display: inline-block;
  margin: 0 auto;
}

#logos img {
width: 100%;
}

}


