/*
Theme Name: RSP Architects
Theme URI: http://www.rsparch.com/
Author: Cimbura.com
Author URI: http://cimbura.com/
Description: RSP Theme
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: white, one-column, responsive-layout, custom-header, custom-menu, editor-style, featured-images, full-width-template, post-formats
Text Domain: rsparch
Template: genesis
Template Version: 2.0

RSP is based on Underscores http://underscores.me/, (C) 2012-2015 Automattic, Inc. and is a genesis child thme.
*/
/* ---------------------------------------------------------------------
 RESET CSS (thanks Eric Meyer)
------------------------------------------------------------------------ */
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-weight: inherit;
  font-style: inherit;
  font-family: inherit;
  vertical-align: baseline; }

html {
  box-sizing: border-box;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%; }

body {
  line-height: 1;
}

html,body {
	height:100%;
}

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; }

:focus {
  outline: 0;
}

/* ---------------------------------------------------------------------
 HTML5 Block / Inline Block declarations
------------------------------------------------------------------------ */
article, aside, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section {
  display: block; }

audio, canvas, video {
  display: inline-block; }

/* ---------------------------------------------------------------------
 Form Reset Styles
------------------------------------------------------------------------ */
input,
button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  border-radius: 0; }

input[type=submit],
button {
  display: inline-block;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  text-align: left;
  color: inherit;
  cursor: pointer; }

textarea {
  overflow: auto;
  vertical-align: top;
  resize: none; }

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

/* ---------------------------------------------------------------------
 Box Sizing
------------------------------------------------------------------------ */
*, *:before, *:after {
  box-sizing: inherit; }

html {
  box-sizing: border-box; }

/* ---------------------------------------------------------------------
 Image Defaults
------------------------------------------------------------------------ */
img {
  display: block;
  max-width: 100%; }

/* ---------------------------------------------------------------------
 Make sure embeds and iframes fit their containers!
------------------------------------------------------------------------ */
embed,
iframe,
object {
  max-width: 100%; }

/* ---------------------------------------------------------------------
 Required WP Styles - don't leave these out
------------------------------------------------------------------------ */
.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em; }

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em; }

.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto; }

.wp-caption {
  margin-bottom: 1.5em;
  max-width: 100%;
}
.wp-caption img[class*="wp-image-"] {
  display: block;
  margin-left: auto;
  margin-right: auto; }
.wp-caption .wp-caption-text {
  margin: 0.8075em 0 0 0;
}

.wp-caption-text {
	text-align: left;
}
figcaption {
	font-size: 1rem;
}
.gallery {
  margin-bottom: 1.5em; }

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%; }
  .gallery-columns-2 .gallery-item {
	max-width: 50%; }
  .gallery-columns-3 .gallery-item {
	max-width: 33.33%; }
  .gallery-columns-4 .gallery-item {
	max-width: 25%; }
  .gallery-columns-5 .gallery-item {
	max-width: 20%; }
  .gallery-columns-6 .gallery-item {
	max-width: 16.66%; }
  .gallery-columns-7 .gallery-item {
	max-width: 14.28%; }
  .gallery-columns-8 .gallery-item {
	max-width: 12.5%; }
  .gallery-columns-9 .gallery-item {
	max-width: 11.11%; }

.gallery-caption {
  display: block; }


/* ---------------------------------------------------------------------
 Body
------------------------------------------------------------------------ */
body {
  font: 1em "Roboto", sans-serif;
  font-weight: 300;
  color: #000000;
  line-height: 1.4;
}

/* isFlyInOpen styles */
body.isFlyInOpen {
  width: 100%;
  position: fixed; }
/* ---------------------------------------------------------------------
 Headers
------------------------------------------------------------------------ */
h1,
h2,
h3,
h4,
h5 {
  font-family: "Oswald",sans-serif;
  font-weight: 700;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}
h1 { font-size: 3em; }
h2 { font-size: 1.5em; }
h3 { font-size: 1.17em; }
h4 { font-size: 1.12em; }
h5 { font-size: .83em; }
h6 { font-size: .75em; }

/* ---------------------------------------------------------------------
 Post Formatting
------------------------------------------------------------------------ */

p {
  margin-bottom: 14px;
}

a:hover,
a:active {
  color:#7bafde;
}

/* ---------------------------------------------------------------------
 Soliloquy
------------------------------------------------------------------------ */
#slider .sol-caption-wrap {
  margin: 0 auto;
  position: relative;
}
#slider .sol-caption-underline,
.hero .overlay .overlay-text-ul {
  border-bottom: 4px solid #fff;
  position: relative;
  bottom: 0;
  left: -10px;
  width: 15%;
  margin: 10px 0;
}
#slider .sol-caption-lm a,
.hero .overlay .overlay-link-text a,
.hero-caption-wrap {
  position: relative;
  bottom: 0;
  color: #fff;
  font-weight: 300;
  font-size: 1.2em;
  text-transform: uppercase;
}
#slider .soliloquy-caption {
  top: 0;
  background: rgba(0,0,0,0.5);
}
#slider .soliloquy-caption-inside,
.hero .overlay .overlay-text-section, {
  padding: 0;
  font-family: 'Oswald',sans-serif;
  font-size: 2em;
  font-weight:700;
  text-align: left;
  text-shadow: none;
  background: none;
  width: 60%;
  position: absolute;
  bottom: 80px;
  letter-spacing: 2px;
  line-height: 1.2em;
}
@media screen and (max-width: 700px) {
  #slider .soliloquy-caption-inside,
  .hero .overlay .overlay-text-section {
	font-size: 1.5em;
  }
}
/* ---------------------------------------------------------------------
 Hero Image
------------------------------------------------------------------------ */
.imagebg.hero {
	position: relative;
}
.hero-overlay {
	height: 100%;
	width: 100%;
	background: rgba(0,0,0,0.4);
}
.hero-caption-wrap {
	position: absolute;
	bottom: 10%;
	width: 80%;
	left: 0;
	padding-left: 20px;
}
.hero-caption-wrap a {
	width: 100%;
	display: block;
	padding-right: 50%;
}
.hero-caption {
	padding: 0;
	font-family: 'Oswald',sans-serif;
	font-size: 2em;
	line-height: 1.2;
	text-transform: none;
	font-weight:700;
	text-align: left;
	text-shadow: none;
	background: none;
}
.hero-caption-ul {
	border-bottom: 4px solid #fff;
	position: relative;
	bottom: 0;
	left: -10px;
	width: 200px;
	margin: 10px 0;
}
.hero-link-text {
	font-family: 'Roboto',sans-serif;
	font-size: 1.4rem;
}
a:hover .hero-caption-ul {
	border-bottom: 4px solid #7bafde;
}


/* ---------------------------------------------------------------------
 Anchors
------------------------------------------------------------------------ */
a {
  color: inherit;
  text-decoration: none; }

/* ---------------------------------------------------------------------
 Page
------------------------------------------------------------------------ */
.page-body {
  position: relative;
  top: 8px;
  z-index: 1;
}
/* ---------------------------------------------------------------------
 Wrapper
------------------------------------------------------------------------ */
.site-inner,
.wrapper,
.breadcrumbs-wrapper,
.overlay-text-wrapper,
#slider .sol-caption-wrap {
  padding: 0 20px;
}
.wrapper {
  position: relative;
  top: 30px;
}

.entry-content {
  margin-top: 30px;
}

h1.fp-title.entry-title,
.related-posts h2,
.fp-title,
.entry-title,
.entry-title h1 {
	font-size: 2rem;
	line-height: 2.4rem;
}
.content p:first-of-type {
  padding-top: 9px;
}
.fact-content {
	line-height: 1rem;
	font-size: .825rem;
}
.fact-content ul,
.fact-content ol,
.content ul,
.content ol {
  margin: 6px 0;
  padding-left: 1rem;
}
.fact-content ul,
.content ul {
	list-style: disc;
}
.fact-content ol,
.content ol {
  list-style-type: decimal;
}
strong {
  font-weight: 700;
}
em {
  font-style: italic;
}
blockquote {
	display: block;
	font-size: 1.4rem;
	line-height: 1.7rem;
	width: 80%;
	margin: 0 auto;
	font-weight: 400;
	color: #A9A19C;
	text-align: left;
}

blockquote cite {
	display: block;
	font-size: 1.2rem;
	font-weight: 300;
}

blockquote cite:before {
content: "\2014 \2009";
}
.entry-content a {
	color: rgb(34, 137, 179);
}
.entry-content a:hover {
	color: rgb(77, 171, 210);
}
@media screen and (min-width: 960px) {
  .site-inner,
  .wrapper,
  .breadcrumbs-wrapper,
  .overlay-text-wrapper,
   #slider .sol-caption-wrap
   {
	margin: 0 auto;
	width: 80%;
  }
  .hero-caption-wrap {
	left: 10%;
  }
  .single-permapost .site-inner,
  .single-post .site-inner {
	margin: 0 auto;
	width: 60%;
  }
}
/* ---------------------------------------------------------------------
 Services Parent Page
------------------------------------------------------------------------ */
.service-page .single-category{
  position: relative;
  padding: 2px 0;
  overflow: hidden;
}
.service-page .single-category.left,
.service-page .single-category.right {
  width: 50%;
  width: calc(50% - 4px);
  min-height: 240px;
}
.service-page .single-category.left {
  float: left;
}
.service-page .single-category.right {
  float: right;
}
.cat-row {
  overflow: hidden;
  margin-bottom: 2px;
}
.service-page .single-category .cat-thumb {
  width: 100%;
  vertical-align:top;
}
.service-page .single-category h2 {
  position: absolute;
  color:#fff;
  top:5%;
  left:5%;
}

@media screen and (max-width: 768px) {
  .service-page .single-category{
	position: relative;
	padding: 2px 0;
  }
  .service-page .single-category.left,
  .service-page .single-category.right {
	width: 100%;
  }
  .cat-row {
	  overflow: visible;
  }
}
/* ---------------------------------------------------------------------
 Single Person
------------------------------------------------------------------------ */
.contact-info {
  margin: 20px 0;
}
.contact-info .icon {
  width: 20px;
  display: inline-block;
  margin-right: 10px;
}
.contact-info .contact-info-item {
  margin-bottom: 10px;
}

/* ---------------------------------------------------------------------
 Project Type Parent Page / Archive
------------------------------------------------------------------------ */

.type-page .half {
  display: inline-block;
  width: 50%;
  box-sizing: border-box;
}
.type-page .single-category {
  position: relative;
  overflow: hidden;
  display: inline-block;
  height: 100%;
}
.type-page .single-category .tag {
  position: absolute;
  bottom:5%;
  left:5%;
  text-transform: uppercase;
  font-size: .825rem;
}
.type-page .single-category .tag.position {
  display: none;
}
.type-page .solid {
  min-height: 120px;
  height:100%;
}
.blog .type-page .solid {
}
.blog .content {
  margin-top: 80px;
}
.blog .type-page .story-tile .tag {
  color:#fff;
  display:none;
}
.type-page .solid.news {
  border: 4px solid #000;
}
.type-page .news:hover {
  color: #fff;
}
.type-page .news:hover > h2 {
  color:#fff;
}
.type-page.block {
  border: 4px solid #000;
  background-color: #000;
  color: #fff;
}
.type-page.block:hover {
  background-color: #fff;
}
.type-page.block:hover h2,
.type-page.block:hover .tag  {
  color:#000;
}
.type-page .solid.perspective {
  background-color: #0074bc;
  color: #fff;
}
.type-page a .solid.perspective:hover {
  color: #fff;
}
.type-page .solid.results {
  background-color: #000;
  color:#fff;
}
.type-page .solid.news h2 {
  color: #000;
}
.type-page .single-category.left:nth-of-type(1),
.type-page .single-category.right:nth-of-type(2) {
  width: 50%;
  width: calc(50% - 8px);
}
.type-page .single-category.left:nth-of-type(1) {
 margin-right: 8px;
}
.type-page .single-category.right:nth-of-type(2) {
 margin-left: 8px;
}
.type-page .single-category.left:nth-of-type(2),
.type-page .single-category.right:nth-of-type(1) {
  width: 50%;
  width: calc(50% - 8px);
}
.type-page .single-category.left:nth-of-type(2) {
 margin-right: 2px;
}
.type-page .single-category.right:nth-of-type(1) {
 margin-left: 2px;
}
.type-page .single-category img {
  width: 100%;
  height: auto;
}
.type-page .single-category .project-title {
  position: absolute;
  color:#fff;
  top:5%;
  left:5%;
  padding-right: 5%;
}
.type-page .single-category .project-title h2 {
  margin-bottom: 0;
}
.type-page .single-category .solid h2 {
  position: absolute;
  top:5%;
  left:5%;
  padding-right: 5%;
}
.type-page .single-category .project-title .credentials {
  top:0;
  font-size: .825rem;
}
.type-page .single-category .credentials {}
.type-page .single-category .project-title {
  display: none;
}
.ismobile .type-page .single-category .project-title,
.type-page .single-category:hover .project-title {
  display: inline;
}
.type-page .news:hover {
  background-color:#000;
}
.type-page .news:hover > h2,
.type-page .story-tile:hover > .tag,
.type-page .news:hover > .tag,
.type-page .person:hover > .position,
.type-page .person:hover > .project-title {
  color:#fff;
  display: block;
}
.type-page .results:hover {
  background-color:#fff;
  border: solid 4px #000;
}
.type-page .results:hover > h2,
.type-page .results:hover > .tag {
  color:#000;
}
.type-page .perspective:hover {
  background-color:#fff;
  border: 4px solid #0074bc;
}
.type-page .perspective:hover > h2,
.type-page .perspective:hover > .tag {
  color: #0074bc;
}
@media screen and (max-width: 768px) {
  .type-page .half {
	width: 100%;
  }
  .type-page .half .single-category.left:nth-of-type(1),
  .type-page .half .single-category.right:nth-of-type(1) {
	margin: 0 2px 0 0;
	width: 50%;
	width: calc(50% - 2px);
  }
  .type-page .half .single-category.left:nth-of-type(2),
  .type-page .half .single-category.right:nth-of-type(2) {
	margin: 0 0 0 2px;
	width: 50%;
	width: calc(50% - 2px);
  }
}
@media screen and (min-width: 1200px) {
	.type-page .single-category .tag,
	.type-page .single-category .project-title .credentials {
		font-size: 1.4rem;
	}
}
/* ---------------------------------------------------------------------
 Project Type / Archive
------------------------------------------------------------------------ */
.post-wrapper {
  margin-bottom: 40px;
}
.post-wrapper.closed .post-tile:nth-child(n+9) {
  display: none;
}
.post-wrapper .post-tile:nth-child(n+9){
  display: block;
}

.post-wrapper.closed .post-tile.news:nth-child(n+5) {
  display: none;
}
.post-wrapper .post-tile.news:nth-child(n+5){
  display: block;
}


.post-heading {
  font-size: 2rem;
}
.post-heading .more-posts {
  padding: 0 10px;
  cursor: pointer;
  position: relative;
  font-size: 32px;
  line-height: 48px;
}
.post-heading .more-posts.plus::before {
  content: "+ ";
  top: 1px;
  left: 12px;
  position: absolute;
}
.post-heading .more-posts.plus::after {
  content: " more";
  top: 1px;
  left: 32px;
  position: absolute;
}
.post-heading .more-posts::before {
  content: "- ";
  top: -1px;
  left: 12px;
  position: absolute;
}
.post-heading .more-posts::after {
  content: " less";
  font-size: .5em;
  top: 1px;
  left: 32px;
  position: absolute;
}



.post-tiles-container {
  display: flex;
  flex-wrap: wrap;
  overflow: hidden;
}
.post-tile {
  display: block;
}
.post-wrapper .post-tile:nth-child(2n+1) .post-box {
  margin-left: 0;
}
.post-wrapper .post-tile:nth-child(2n) .post-box {
  margin-right: 0;
}

.post-tile .post-box {
  display: block;
  position: relative;
  height: 100%;
}
.post-tile .post-box .project-title,
.post-tile .post-box .post-title {
  position: absolute;
  top:5%;
  left:5%;
  padding-right: 5%;
}
.post-tile .post-box h3 {
  margin-bottom: 0;
  font-size: 1.2rem
}

.post-tile .post-box .project-title {
  display: none;
  color:#fff;
}
.post-tile:hover .post-box .project-title {
  display: block;
}



/* Team Section */
.post-tile .post-box .tag.position {
  display: none;
  color:#fff;
}
.post-tile:hover .post-box .tag.position {
  display: block;
}
.post-tile img {
  width: 100%;
}

/* News Section */
.post-tile, .solid  {
  min-height: 30.25vw;
  height: 100%;
}
.post-tile .solid,
.post-tile .solid.news {
  border: 4px solid #000;
  height: 100%;
}
.post-tile .solid:hover,
.post-tile .solid.news:hover {
  background-color: #000;
  color: #fff;
}
.post-tile .solid.results {
  background-color: #000;
  color: #fff;
}
.post-tile .solid.results:hover {
  background-color: #fff;
  color: #000;
  border: 4px solid #000;
}
.post-tile .solid.perspective {
  background-color: #0074bc;
  color: #fff;
  border: none;
}
.post-tile .solid.perspective:hover {
  background-color: #fff;
  color: #0074bc;
  border: 4px solid #0074bc;
}


.post-tile .tag {
  position: absolute;
  bottom: 5%;
  left: 5%;
  text-transform: uppercase;
  font-size: .825rem;
}


@media screen and (min-width: 768px) {
  .post-tile, .solid  {
	min-height: 16.125vw;
  }
}
@media screen and (min-width: 992px) {

}

@media screen and (min-width: 1200px) {
  .post-tile .tag,
  .post-tile .credentials {
	font-size: 1.4rem;
  }
  .post-tile .post-box h3 {
	font-size: 1.8rem;
	line-height: 2.2rem;
  }
}

/* ---------------------------------------------------------------------
 Grid
------------------------------------------------------------------------ */
.grid-col {
  margin-bottom: 20px; }

@media screen and (min-width: 768px) {
  .grid {
	margin-bottom: 20px;
	margin-left: -20px;
	font-size: 0; }

  .grid-col {
	margin-bottom: 0;
	display: inline-block;
	padding-left: 20px;
	font-size: medium;
	vertical-align: top; }

  .grid-col_1of12 {
	width: 8.3333%; }

  .grid-col_2of12 {
	width: 16.6666%; }

  .grid-col_3of12 {
	width: 25%; }

  .grid-col_4of12 {
	width: 33.3333%; }

  .grid-col_5of12 {
	width: 41.6666%; }

  .grid-col_6of12 {
	width: 50%; }

  .grid-col_7of12 {
	width: 58.3334%; }

  .grid-col_8of12 {
	width: 66.6667%; }

  .grid-col_9of12 {
	width: 75%; }

  .grid-col_10of12 {
	width: 83.3334%; }

  .grid-col_11of12 {
	width: 91.6667%; }

  .grid-col_12of12 {
	  width: 100%; }
}
/* ---------------------------------------------------------------------
 Multisize Tile Gallery
------------------------------------------------------------------------ */
.rsp-tg-wrap,
.rsp-tg-wrap .tg-row,
.rsp-tg-wrap .tg-col {
  overflow: hidden;
  line-height: 0;
}
.rsp-tg-wrap .tg-row {
  margin-bottom: 0;
}
.rsp-tg-wrap .tg-col {
  width: 50%;
  display: inline-block;
}
.rsp-tg-halfl {
  width: 50%;
  width: calc(50% - 4px);
  float:left;
  overflow: hidden;
  margin-right: 4px;
}
.rsp-tg-halfr {
  width: 50%;
  width: calc(50% - 4px);
  float:right;
  overflow: hidden;
  margin-left: 4px;
}

.rsp-tg-halfl .tg-small:nth-of-type(1),
.rsp-tg-row1 .rsp-tg-col1 .tg-item:nth-of-type(1),
.rsp-tg-row1 .rsp-tg-col1 .tg-item:nth-of-type(2),
.rsp-tg-row2 .rsp-tg-col2 .tg-item:nth-of-type(1),
.rsp-tg-row2 .rsp-tg-col2 .tg-item:nth-of-type(2) {
  margin-bottom: 8px;
}
.rsp-tg-row1 .rsp-tg-col1 .tg-item:nth-of-type(1),
.rsp-tg-row2 .rsp-tg-col2 .tg-item:nth-of-type(1),
.rsp-tg-row1 .rsp-tg-col1 .tg-item:nth-of-type(3),
.rsp-tg-row2 .rsp-tg-col2 .tg-item:nth-of-type(3) {
  margin-right: 1px;
}
.rsp-tg-row1 .rsp-tg-col1 .tg-item:nth-of-type(4),
.rsp-tg-row2 .rsp-tg-col2 .tg-item:nth-of-type(4) {
 margin-left: 1px;
}
.rsp-tg-wrap  .rsp-tg-halfl .tg-small,
.rsp-tg-wrap  .rsp-tg-halfr .tg-small,
.rsp-tg-wrap  .rsp-tg-halfl .tg-medium,
.rsp-tg-wrap  .rsp-tg-halfr .tg-medium {
  width: 100%;
}
.rsp-tg-wrap  .rsp-tg-halfr .tg-medium {
  margin-bottom: 4px;
}
.rsp-tg-wrap .rsp-tg-col1,
.rsp-tg-wrap .rsp-tg-col2  {
  width: 50%;
  width: calc(50% - 4px);
}
.rsp-tg-wrap .rsp-tg-col2 {
  float: right;
}

.rsp-tg-wrap .rsp-tgol1 {

}
.rsp-tg-wrap .tg-small,
.rsp-tg-wrap .tg-medium {
  width: 50%;
  width: calc(50% - 4px);
}
.rsp-tg-wrap .tg-small img,
.rsp-tg-wrap .tg-large {
  width: 101%;
}
.rsp-tg-wrap .tg-item {
  float:left;
  overflow: hidden;
}
.rsp-tg-wrap img {
  width: 102%;
  margin:0;
}
.tg-medium {
  background-color: blue;
  height:100%;
}
.tg-item {
  position: relative;
}
.tg-item h2 {
	position: absolute;
	top: 5%;
	left: 5%;
	padding-right: 5%;
	letter-spacing: .5px;
	line-height: 1.2rem;
	font-size: 1rem;
}
.type-page h2.quote,
.tg-item h2.quote {
	text-transform: none;
}

h2.project-title,
.project-title h2,
.tg-item h2,
.service-page h2,
.solid h2 {
	padding-right: 5%;
	letter-spacing: .5px;
	line-height: 1.2rem;
	font-size: 1rem;
}
.tg-item a {
  display: block;
  height: 100%;
}
.tg-item .opaque-wrap {
  width: calc( 100% + 4px );
  overflow: hidden;
  margin: 0 auto;
}
.tg-item .tag {
  position: absolute;
  left: 5%;
  bottom: 7%;
  text-transform: uppercase;
  font-size: .825rem;
}
.rsp_fact.tg-item .top-content {
  position: absolute;
  left: 5%;
  top: 2.5%;
  padding-right: 5%;
  text-transform: inherit ;
  font-weight: 400;
}
.rsp_fact.tg-item .top-content h2 {
  font-size: 1.4rem;
  line-height: 1.6rem;
  margin:0 0 6px 0;
  padding: 0;
  position: relative;
  left:0;
}
.rsp_fact.tg-item .tag {
  display: none;
}
.rsp_project.tg-item h2 {
  display: none;
  color: #fff;
}
.rsp_project.tg-item .tag {
  color: #fff;
}
.ismobile .rsp_project.tg-item h2,
.ismobile .rsp_project.tg-item .tag,
.rsp_project.tg-item:hover h2,
.rsp_project.tg-item:hover .tag {
  display: inline;
}
.news.tg-item {
  background-color: #fff;
  border: solid 4px #000;
  color: #000;
}
.pov.tg-item {
  background-color: #0074bc;
  border: solid 4px #0074bc;
  color: #fff;
}
.results.tg-item {
  background-color: #000;
  border: solid 4px #000;
  color: #fff;
}
.fact.tg-item {
  background-color: #7bafde;
  color: #000;
}
.pov.tg-item:hover,
.pov.tg-item a:hover  {
  background-color: #fff;
  color: #0074bc;
}
.results.tg-item:hover,
.results.tg-item a:hover  {
  background-color: #fff;
  color: #000;
}
.news.tg-item:hover,
.news.tg-item a:hover  {
  background-color: #000;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .rsp-tg-wrap .tg-col {
	width:100%;
	float:none;
  }
  .rsp-tg-col1 {
	margin-bottom: 4px;
  }
  .rsp-tg-row1 .rsp-tg-col1 {
	margin-bottom: 0px;
  }
  .rsp-tg-row1 .rsp-tg-col2 {
		margin-bottom: 4px;
	}
	.hero-caption-wrap a {
		padding-right: 20%;
	}
}
@media screen and (min-width: 490px) {
	.related-posts h2,
	.fp-title,
	h1.entry-title,
	.entry-title h1 {
		font-size: 2rem;
		line-height: 2.4rem;
	}
  h2.project-title,
  .project-title h2,
  .tg-item h2,
  .solid h2 {
	font-size: 1.6rem;
	line-height: 2rem;
  }
  .rsp_fact.tg-item .top-content h2 {
	  font-size: 1.6rem;
	  line-height: 2rem;
  }
  .related-posts .related-tag,
  .tg-item .tag {
	 font-size: .825rem;
  }
  .fact-content {
	  font-size: .825rem;
	  line-height: 1rem;

  }
  .fact-content ul,
  .fact-content ol,
  .content ul,
  .content ol {
	margin: 6px 0;
	padding-left: 2rem;
  }
}
@media screen and (min-width: 768px) {
	.related-posts h2,
	.fp-title,
	h1.fp-title.entry-title,
	.entry-title,
	.entry-title h1 {
		font-size: 2.8rem;
		line-height: 3.2rem;
	}
	h2.project-title,
	.project-title h2,
	.tg-item h2,
	.solid h2,
	.service-page h2 {
		font-size: 1.2rem;
		line-height: 1.6rem;
	}
	.rsp_fact.tg-item .top-content h2 {
		font-size: 1.4rem;
		line-height: 1.8rem;
	}
	.fact-content {
		font-size: .825rem;
		line-height: 1rem;
	}
}
@media screen and (min-width: 1130px) {
	.related-posts h2,
	.fp-title,
	.entry-title h1 {
		font-size: 3rem;
		line-height: 3.4rem;
	}
  h2.project-title,
  .project-title h2,
  .service-page h2,
  .tg-item h2,
  .solid h2 {
	font-size: 1.8rem;
	line-height: 2.2rem;
  }
  .rsp_fact.tg-item .top-content h2 {
	font-size: 2.2rem;
	line-height: 2.6rem;
	margin-bottom: 20px;
  }
  .fact-content {
	  font-size: 1rem;
	line-height: 1.2rem;

  }
}
@media screen and (min-width: 1400px) {

	.fp-title,
	.entry-title h1 {
	  font-size: 3.4rem;
	  line-height: 3.8rem;
	}
	h2.project-title,
	.project-title h2,
	.service-page h2,
	.tg-item h2,
	.solid h2 {
		font-size: 2.45rem;
		line-height: 2.95rem;
	}
	.rsp_fact.tg-item .top-content h2 {
		font-size: 3rem;
		line-height: 3.2rem;
	}
	.related-posts .related-tag,
	.tg-item .tag {
		font-size: 1.4rem;
	}
	.fact-content {
		font-size: 1.2rem;
		line-height: 1.6rem;
	}
}
/* ---------------------------------------------------------------------
Related Posts Archive Tile Gallery
------------------------------------------------------------------------ */
.related-wrapper {
  margin-bottom: 40px;
}
.post-tiles-container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 8px;
}
.related-wrapper.closed .post-tile:nth-child(n+5) {
  display: none !important;
}
.related-wrapper .post-tile:nth-child(n+9){
  display: block !important;

}

.related-wrapper h2.post-heading {
  font-size: 2rem;
  line-height: 2.4rem;
  padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .post-tiles-container {
	grid-template-columns: 1fr 1fr 1fr 1fr;
}
  .related-wrapper h2.post-heading {
	font-size: 2.8rem;
	line-height: 3.2rem;
  }
}
@media screen and (min-width: 1130px) {
  .related-wrapper h2.post-heading {
	font-size: 3rem;
	line-height: 3.4rem;
  }
}

/* ---------------------------------------------------------------------
 Archive Tile Gallery
------------------------------------------------------------------------ */
.archive-content,
.archive-row,
.archive-column {
  overflow: hidden;
}
/* ---------------------------------------------------------------------
 Related Posts
------------------------------------------------------------------------ */
.related-posts {
  width: 100%;
  margin: 60px 0;
}
.related-posts h3,
.related-posts .related-tag {
  font-size: 2em;
  letter-spacing: normal;
  text-transform: uppercase;
  font-weight: bold;
  font-family: "Oswald",sans-serif;
}
.related-posts .related-wrap {
  position: relative;
  padding: 0 0 30px 0;
  top: 80px;

}
.related-posts .related-item {
  display: inline-block;
  width:25%;
  width: calc( 25% - 8px);
  padding-right: 8px;

}
.related-posts .related-item:last-of-type {
  padding: 0;
}
.related-posts .related-text {
  padding: 0 20px;
}
.related-posts .related-image {
  position: relative;
  margin-bottom:40px;
}
.related-posts .related-image {
  position: relative;
  margin-bottom:40px;
}
.related-posts .noimage .related-image  {
	border: 4px solid #000;
}
.related-posts .noimage h3 {
	max-width: 300px;
}
.related-posts .related-item img {
  width: 100%;
}
.related-posts .related-item.noimage .related-text {
	position: absolute;
	top  : 20px;
}
.related-posts .related-image:before {
  content : "";
  position: absolute;
  left    : 0;
  right    : 0;
  bottom  : -20px;
  height  : 1px;
  width   : 50%;  /* or 100px */
  margin: 0 auto;
  display: block;
  border-bottom:1px solid black;
}

.slick-prev,
.slick-next {
	top: -30px;
	width: 40px;
	height: 40px;
	z-index: 999;
}
.slick-prev
{
	left: 25px;
	z-index:10;
}
[dir='rtl'] .slick-prev
{
	right: 25px;
	left: auto;
}
.slick-prev:before,
.slick-next:before {
	font-size: 40px;
	line-height: 40px;
	opacity: .90;
	color: #0074BC;
	display: inline-block;
	font-family: 'FontAwesome';
}
.slick-prev:before
{
	content: '\f104';
}
[dir='rtl'] .slick-prev:before
{
	content: '\f105';
}

.slick-next
{
	right: 25px;
}
[dir='rtl'] .slick-next
{
	right: auto;
	left: 25px;
}
.slick-next:before
{
	content: '\f105';
}
[dir='rtl'] .slick-next:before
{
	content: '\f104';
}

/* ---------------------------------------------------------------------
 Header
------------------------------------------------------------------------ */
.site-header {
  margin-top: 40px;
}
#header-topbar {
  position: fixed;
  background: #000;
  height: 50px;
  width:100%;
  top:0;
  z-index: 10;
  overflow: hidden;
}
#header-topbar .site-logo {
  display: inline-block;
  position: relative;
  top: 13px;
  left: 10px;
}
#header-topbar .rsp-logo {
  height:50px;
  width: 60px;
  background-image: url(images/rsp-logo.svg);
  background-repeat: no-repeat;
  background-size: 55px;
}
#header-topbar .right-topbar {
  float: right;
  text-align: right;
  padding-top: 8px;
}
#header-topbar .search {
  display: inline-block;
}
#header-topbar .social-icons {
  display: inline-block;
  padding-right: 10px;
  position: relative;
  top: 5px;
}
.social-icons .social-icon {
  height: 30px;
  width: 30px;
  display: inline-block;
  margin-right: -4px;
}
.social-icons .instagram-icon {
  background: url(./images/social-icons/RSP_Insta.png) no-repeat;
  background-size: 30px;
  background-position: bottom;
  position: relative; top: -1px;
}
.social-icons .facebook-icon {
  background: url(./images/social-icons/RSP_FB.PNG) no-repeat;
  background-size: 30px;
  background-position: bottom;
}
.social-icons .twitter-icon {
  background: url(./images/social-icons/RSP_Twitter.png) no-repeat;
  background-size: 30px;
  background-position: bottom;
  margin-right: 1px;
}
.social-icons .linkedin-icon {
  background: url(./images/social-icons/RSP_LinkedIn.png) no-repeat;
  background-size: 30px;
  background-position: bottom;
  margin-right: 5px;
}
body.admin-bar #header-topbar {
  top: 32px;
}
body.admin-bar .navicon-text {
  top: 64px;
}
body.admin-bar .flyIn-trigger {
  top: 34px;
}
body.admin-bar .flyIn-panel{
  top: 82px;

}
@media screen and (max-width: 782px) {
  body.admin-bar #header-topbar {
	top: 36px;
  }
  body.admin-bar .navicon-text {
	top: 68px;
  }
  body.admin-bar .flyIn-trigger {
	top: 40px;
  }
  body.admin-bar .flyIn-panel{
	top: 86px;
  }
  #header-topbar .social-icons {
	padding-right: 10px;
  }
}
/* ---------------------------------------------------------------------
 Search Input
------------------------------------------------------------------------ */
.search {
  position: relative;

}
#header-topbar input {
  margin-left: 5px;
  padding-left: 35px;
  height: 30px;
  width: 0px;
  background: url(images/search-icon.svg) no-repeat;
  background-size: 22px;
  background-position: bottom;
  border: none;
  outline: none;
  color: transparent;
  font-size: 20px;
  position: relative !important;
  bottom: 5px;
}
#header-topbar input:hover {
  cursor: pointer;
}
#header-topbar input:focus {
  width: 300px;
  background: url(images/search-icon-active.svg) no-repeat;
  background-color: #eee;
  color: #111;
  background-position: 5px;
  background-size: 22px;

}
#header-topbar input:focus:hover {
  cursor: text;
}
@media screen and (max-width: 768px) {
  .navicon-text.searchactive,
  .searchactive {
	display:none;
  }
  #header-topbar input:focus {
	width: 200px;
  }
}
/* ---------------------------------------------------------------------
 FlyIn
------------------------------------------------------------------------ */
.flyIn > * {
  position: fixed; }

.flyIn > *,
.flyIn-trigger:before,
.flyIn-trigger:after {
  transition: all 300ms ease-in-out; }

.flyIn-trigger {
  width: 40px;
  height: 40px;
  border: 2px solid #000;
  top: 2px;
  left: 75px;
  z-index: 101;
  font-size: 0;
  color:#fff;
  }
.navicon-text {
  position: fixed;
  display: block;
  width:40px;
  height: 20px;
  top:32px;
  left: 75px;
  color: #fff;
  z-index: 102;
  text-align: center;
  font-size: 10px;
}
.flyIn-trigger:before,
.flyIn-trigger:after {
  content: '';
  display: block;
  width: 26px;
  border-top: 2px solid #fff;
  position: absolute;
  left: 5px;
  -webkit-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0); }

.flyIn-trigger:before {
  height: 14px;
  border-bottom: 2px solid #fff;
  top: 11px; }

.flyIn-trigger:after {
  top: 17px;  }

  .flyIn-panel {
	width: 200px;
	height: 100%;
	top: 50px;
	bottom: 0;
	left: -200px;
	z-index: 100;
	background-color: rgba(0, 0, 0, 0.7);
	opacity: 0; }

/* isFlyInOpen styles */
.isFlyInOpen .flyIn-trigger:before {
  height: 0;
  border-bottom-width: 0;
  top: 17px;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }

.isFlyInOpen .flyIn-trigger:after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg); }

.isFlyInOpen .flyIn-trigger {
  background-color: rgba(255, 255, 255, 0); }

.isFlyInOpen .flyIn-panel {
  left: 0;
  opacity: 1; }

/* ---------------------------------------------------------------------
 nav
------------------------------------------------------------------------ */
.nav,
.nav > * {
  font-family: 'Roboto',sans-serif;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0; }

.nav {
  border-top: 1px solid rgba(255, 255, 255, 0.2); }

.nav > * {
  padding: 15px; }

.nav-list {
  bottom: 120px;
  overflow: auto;
  font-weight: bold;
}
.nav-list .subNav {
  font-weight: normal;
}

.nav-list > * + * {
  margin-top: 10px; }

.nav-list > * > * {
  display: block;
  letter-spacing: 1px;
  font-size: 15px;
  line-height: 1;
  color: #ffffff;
  text-transform: uppercase;;
  text-decoration: none; }

.nav-search {
  height: 120px;
  top: auto; }

/* ---------------------------------------------------------------------
 SubNav
------------------------------------------------------------------------ */
.subNav {
  margin: 10px 0 0 10px; }

.subNav > * + * {
  margin-top: 10px; }

.subNav > * > * {
  font-size: 14px;
  line-height: 1;
  color: #ffffff;
  text-decoration: none;
}

.nav-list .subNav .subNav li a{
  text-transform: capitalize;
  font-size: 12px;
}

/* ---------------------------------------------------------------------
 Footer
------------------------------------------------------------------------ */
.site-footer{
  overflow: hidden;
  margin: 0 auto 30px;
}
.scrolltotop {
  text-align: right;
}
.scrolltotop img {
  display: inline-block;
  height: 30px;
  width: 50px;
}
.scrollup {
  cursor: pointer;
}
@media screen and (max-width: 768px) {

  .scrolltotop {
	margin-top: 40px;
  }
}
/* ---------------------------------------------------------------------
 Responsive Video Embeds
------------------------------------------------------------------------ */
.oembed-container {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}
.oembed-container iframe,
.oembed-container object,
.oembed-container embed,
.oembed-container video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/* ---------------------------------------------------------------------
 Search Form
------------------------------------------------------------------------ */
.searchForm {
  position: relative;
  left: 5px;
}

.searchForm-input {
  display: block;
  margin-bottom: 10px;
  width: 100%;
  padding: 5px 5px 5px 28px;
  border: none;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  font-size: 12px;
  line-height: 1; }

.searchForm-label {
  width: 16px;
  height: 18px;
  position: absolute;
  top: 4px;
  left: 5px;
  z-index: 2;
  background: transparent url("images/search-icon.jpg") 0 0 no-repeat;
  font-size: 0; }

.searchForm-copyRight {
  font-size: 8px;
  color: #ffffff; }

/* _callout extension styles */
.searchForm_callout {
  display: inline-block;
  line-height: 0; }

.searchForm_callout .searchForm-input {
  margin-bottom: 30px;
  padding: 10px 10px 10px 33px;
  border: 1px solid #000;
}

.searchForm_callout .searchForm-label {
  top: 8px;
  left: 8px; }

/* _constrain mixin */
.mix-searchForm_constrain {
  width: 180px; }

@media screen and (min-width: 768px) {
  .mix-searchForm_constrain {
	width: 200px; } }
/* ---------------------------------------------------------------------
 Locations Page
------------------------------------------------------------------------ */
.single-location {
  overflow: hidden;
  margin-bottom: 40px;
}
.single-location .location-map {
  overflow: hidden;
}
.single-location .directions,
.single-location .careers {
  margin:10px 0;
}


@media screen and (max-width: 1380px) {
	.single-location .contact-info li {
		margin-bottom: .5rem;
	}
	.contact-info .contact-title {
		display: block;
	}
}
/* ---------------------------------------------------------------------
 Careers Page
------------------------------------------------------------------------ */
.location .career-heading {
  font-size: 1.25em;
}
.location .single-career {
  margin-bottom: 8px;
}
.location .single-career .rarrow {
  display: inline-block;
  position: relative;
  top: 4px;
}
.emp-disclaimer {
	font-size: 1rem;
	margin-bottom: 4rem;
	width: 90%;
	margin: 0 auto;
}
a .btn, a.btn {
  background: #fff;
  background-color: #fff;
  color: #000;
  padding: 20px 20px;
  border: 2px solid #000;
  margin: 10px 0;
  display: inline-block;
  font-family: "Oswald",sans-serif;
  font-weight: 700;
  text-transform: uppercase;
}
a .btn:hover, a.btn:hover {

  background: #000;
  background-color: #000;
  color: #fff;
}
.anchored-career-link-wrapper {
  background: #fff;
  background-color: #fff;
  color: #000;
  border: 2px solid #000;
  font-family: "Oswald",sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  position: fixed;
  right: 0;
  top: 75%;
  width: 165px;

  text-align: right;
  padding: 15px 15px;
  font-size: 1.2rem;
  line-height: 1.6rem;
  z-index: 999;
}
.anchored-career-link-wrapper:hover {
  background: #000;
  background-color: #000;
  color: #fff;
}

@media screen and (min-width: 800px) {
	.emp-disclaimer {
		width: 70%;
  }
  .anchored-career-link-wrapper {
	font-size: 1.6rem;
	line-height: 2rem;
	width: 220px;
  }
}




/* ---------------------------------------------------------------------
 Hero
------------------------------------------------------------------------ */
.hero {
	overflow: hidden;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
#slider pre {
	display: none;
}
.hero .slick-arrow {
	position: absolute;
	top: 50%;
}
.hero .slick-prev:before,
.hero .slick-next:before {
	font-size: 40px;
	line-height: 40px;
	opacity: .90;
	color: rgba(255,255,255, 0.4);
	display: inline-block;
	font-family: 'FontAwesome';
}
.hero .slick-prev:hover:before,
.hero .slick-next:hover:before {
	color: rgba(255,255,255, 1);
}
/**
 * hero area can contain video, image, or soliloquoy slideshow
 * DO NOT target img else you'll affect soliloquoy slideshow images as well
 */
.hero video,
.hero .wp-video,
.hero img.hero-img {
  width: 100%    !important;
  height: auto   !important;
  overflow: hidden;
  position: relative;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%); }

.hero iframe {
  height: 100%; }
.hero .overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  top:40px;
}

.hero .overlay .overlay-text-section {
  color: #fff;
  position: absolute;
  bottom: 80px;
}

.videobg {
  position: relative;
  width: 100%; /* Set video container element width here */
  height: 100%; /* Set video container element height here */
  overflow: hidden;
  background: #111; /* bg color, if video is not high enough */
}

/* horizontally center the video */
.videobg-width {
  position: absolute;
  width: 100%; /* Change width value to cover more area*/
  height: 100%;
  left: -9999px;
  right: -9999px;
  margin: auto;
}

/* set video aspect ratio and vertically center */
.videobg-aspect {
  position: absolute;
  width: 100%;
  height: 0;
  top: -9999px;
  bottom: -9999px;
  margin: auto;
  padding-bottom: 56.25%; /* 16:9 ratio */
  overflow: hidden;

}

.videobg-make-height {
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
}

.videobg-hide-controls {
  box-sizing: content-box;
  position: relative;
  height: 100%;
  width: 100%;
  /* Vimeo timeline and play button are ~55px high */
  padding: 55px 97.7777px; /* 16:9 ratio */
  top: -55px;
  left: -97.7777px; /* 16:9 ratio */
}

.videobg iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border: 0 none;
}
@media screen and (max-width: 700px) {
  #slider .soliloquy-caption-inside,
  .hero .overlay .overlay-text-section {
	bottom: 20px;
	width: 100%;
  }
}
/* Custom, iPhone Retina */
@media only screen and (min-width: 320px) {
  .hero,
  .hero .overlay {
	height: 180px; }
   }
/* Extra Small Devices, Phones */
@media only screen and (min-width: 480px) {
  .hero,
  .hero .overlay {
	height: 270px; } }
/* Small Devices, Tablets */
@media only screen and (min-width: 768px) {
  .hero,
  .hero .overlay {
	height: 432px; } }
/* Medium Devices, Desktops */
@media only screen and (min-width: 992px) {
  .hero,
  .hero .overlay {
	height: 558px; } }
/* Large Devices, Wide Screens */
@media only screen and (min-width: 1200px) {
  .hero,
  .hero .overlay {
	height: 675px; } }
/* Large Devices, Wide Screens */
@media only screen and (min-width: 1600px) {
  .hero,
  .hero .overlay {
	height: 900px; } }
/*-----------------------------------
Project Gallery Styling
--------------------------------------*/
.project-gallery-item img {
  width: 100%;
}
.project-gallery {
  margin-bottom: 80px;
}
.project-gallery .gallery-row-1,
.project-gallery .gallery-row-2 {
  width: 100%;
  line-height: 0;
  overflow: hidden;
}

.gallery-row-1 .project-gallery-item {
  width: 50%;
  width: calc(50% - 2px);
  display: inline-block;
  vertical-align: top;
}
.project-gallery .gallery-row-1 {
  margin-bottom: 4px;
}
.gallery-row-1 .project-gallery-item:nth-of-type(1) {
  margin-right: 2px;
}
.gallery-row-1 .project-gallery-item:nth-of-type(2) {
  margin-left: 2px;
}
.gallery-row-2 .project-gallery-item {
  width: 33.33333%;
  width: calc(33.33333% - 3px);
  display: inline-block;
  overflow: hidden;
  margin:0 2px 0 2px;
  vertical-align: top;
}
.gallery-row-2 .project-gallery-item:first-of-type {
  margin:0 2px 0 0;
}
.gallery-row-2 .project-gallery-item:last-of-type {
  margin:0 0 0 2px;
}

/*-----------------------------------
Article Styling
--------------------------------------*/
.entry-content .entry-meta h2,
.entry-content .entry-meta h3,
.entry-content .entry-meta h4,
.entry-content .entry-meta h5,
.entry-content .entry-meta h6,
.entry-content .entry-meta {
  font-family: 'Roboto',sans-serif;
}

.entry-content img {
  max-width: 100%;
  height: auto;
}
.entry-content .entry-meta p,
.entry-meta,
.entry,
.location-content p,
.directions {
  font-size: 16px;
  font-size: 1rem;
  line-height: 20px;
  line-height: 1.2rem;
}
.location-content ul {
	list-style-type: none;
	padding: 0 0 0 20px;
}

/* ---------------------------------------------------------------------
 Toggle
------------------------------------------------------------------------ */
.toggle-trigger {
  display: block;
  padding-right: 20px;
  width: 100%;
  position: relative;
  color: inherit;
  text-transform: inherit;
}

.toggle-trigger:after {
  content: '+';
  display: block;
  width: 20px;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 16px;
  line-height: 1;
  text-align: center;
}
.subnav-toggle .toggle-trigger:after {
  top: 0;
  -webkit-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  transform: translateY(-100%);
}
/* active trigger styling */
.toggle-trigger_isActive:after {
  content: '\2014'; }

.toggle-panel {
  margin: -1px;
  padding: 0;
  border: 0;
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0 0 0 0);
  overflow: hidden; }

/* open panel styling */
.toggle-panel_isOpen {
  margin: 0;
  width: auto;
  height: auto;
  position: static;
  clip: auto;
  overflow: visible; }

/* ---------------------------------------------------------------------
 Blocks
------------------------------------------------------------------------ */
.blocks {
  margin-left: -5px;
  position: relative;
  font-size: 0; }

.blocks > * {
  display: inline-block;
  padding: 0 0 5px 5px;
  font-size: medium;
  vertical-align: top; }

/* number of items extensions */
.blocks_2upTo3upTo4up > * {
  width: 50%; }

@media screen and (min-width: 768px) {
  .blocks_2upTo3upTo4up > * {
	width: 33.3333%; } }
@media screen and (min-width: 960px) {
  .blocks_2upTo3upTo4up > * {
	width: 25%; } }
/* _loose mixin */
.mix-blocks_loose {
  margin-left: -20px; }

.mix-blocks_loose > * {
  padding: 0 0 20px 20px; }

/* _staggered mixin */
.mix-blocks_staggered {
  opacity: 0;
  overflow: hidden; }

.mix-blocks_staggered > * {
  position: absolute;
  opacity: 0;
  transition: opacity 300ms ease-in-out; }

/* ---------------------------------------------------------------------
 Thumb
------------------------------------------------------------------------ */
.thumb,
.thumb-img {
  position: relative; }

.thumb {
  display: block;
  overflow: hidden; }

.thumb-img {
  width: 100%;
  z-index: 1; }

.thumb-caption {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  background-color: #000000;
  background-color: rgba(0, 0, 0, 0.8);
  opacity: 0;
  transition: opacity 300ms ease-in-out; }

.thumb-caption-content {
  position: absolute;
  top: 50%;
  right: 10px;
  left: 10px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 12px;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase;
  color: #ffffff; }

/* active state styling */
.thumb_isActive > .thumb-caption {
  opacity: 1; }

@media screen and (min-width: 768px) {
  .thumb-caption-content {
	right: 10px;
	left: 10px;
	font-size: 15px;
	}
	.entry-content .entry-meta p,
	.entry-meta,
	.entry,
	.location-content li,
	.location-content p,
	.directions  {
	  font-size: 1.2rem;
	  line-height: 1.6rem
	}
}
@media screen and (min-width: 960px) {
  .thumb-caption-content {
	font-size: 18px; } }
/* ---------------------------------------------------------------------
 Tile
------------------------------------------------------------------------ */
.tile {
  display: block;
  padding-bottom: 57.62%;
  width: 100%;
  height: 0;
  border: 1px solid #000000;
  position: relative;
  background-color: #ffffff;
  overflow: hidden; }

.tile-content {
  padding: 20px;
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 12px;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase; }

/* callout extension styles */
.tile_callout {
  background-color: #000000; }

.tile_callout > .tile-content {
  color: #ffffff; }

@media screen and (min-width: 768px) {
  .tile-content {
	font-size: 15px; } }
@media screen and (min-width: 960px) {
  .tile-content {
	font-size: 18px; } }
/* ---------------------------------------------------------------------
 Cycler
------------------------------------------------------------------------ */
.cycler {
  position: relative; }

.cycler > * {
  padding: 10px;
  width: 70%;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  opacity: 0;
  transition: opacity 500ms; }

.cycler_isMiddleAligned > * {
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }

.cycler-cell_isActive {
  opacity: 1; }

/* ---------------------------------------------------------------------
 Blurb
------------------------------------------------------------------------ */
.blurb {
  font-size: 30px;
  line-height: 1.1;
  text-align: center;
}

/* ---------------------------------------------------------------------
 Column Classes
 Link: http://twitter.github.io/bootstrap/assets/css/bootstrap-responsive.css
------------------------------------------------------------------------ */
.col-row {
  overflow: hidden;
  margin: 40px 0;
}

.five-sixths,
.four-sixths,
.four-fifths,
.one-fifth,
.one-fourth,
.one-half,
.one-sixth,
.one-third,
.three-fourths,
.three-fifths,
.three-sixths,
.two-fourths,
.two-fifths,
.two-sixths,
.two-thirds {
	float: left;
	margin-left: 2.564102564102564%;
}

.one-half,
.three-sixths,
.two-fourths {
	width: 48.717948717948715%;
}

.one-third,
.two-sixths {
	width: 31.623931623931625%;
}

.four-sixths,
.two-thirds {
	width: 65.81196581196582%;
}

.one-fourth {
	width: 23.076923076923077%;
}

.three-fourths {
	width: 74.35897435897436%;
}

.one-fifth {
	width: 17.9487179487179488%;
}

.two-fifths {
	width: 38.4615384615384616%;
}

.three-fifths {
	width: 58.9743589743589744%;
}

.four-fifths {
	width: 79.4871794871794872%;
}

.one-sixth {
	width: 14.52991452991453%;
}

.five-sixths {
	width: 82.90598290598291%;
}

.first {
	clear: both;
	margin-left: 0;
}

@media screen and (max-width: 768px) {
  .five-sixths,
  .four-sixths,
  .one-fourth,
  .one-half,
  .one-fifth,
  .one-sixth,
  .one-third,
  .three-fourths,
  .three-sixths,
  .two-fourths,
  .two-sixths,
  .two-thirds {
	float: none;
	display: block;
	width: 100%;
	margin:0;
  }
}
/* ---------------------------------------------------------------------
 Intro
------------------------------------------------------------------------*/
.intro {
  margin-bottom: 30px;
}
h1.entry-title,
.fp-title,
.entry-title,
.intro-heading {
  text-align: left;
  text-transform: uppercase;
  margin-bottom: 40px;
  font-size: 3.4rem;
  line-height: 3.8rem;
}

/* ---------------------------------------------------------------------
 Results
------------------------------------------------------------------------ */
.results {
  padding:0;
  overflow: hidden;
}
.results-heading h1 {
  margin: 40px 0;
  font-size: 2.45rem;
  line-height: 22px;
}
.results .vlist li,
.result-body,
.result-entry {
  overflow: hidden;
}
.result-entry {
  margin-bottom: 20px;
}
.result-media,
.result-content {
  display: inline-block;
  float: left;
}
.results .entry-title {
  font-size: 1.5rem;
  line-height: 1.8rem;
  margin-bottom: 8px;
}
.results .rsp_career .result-media {
  border: 1px #000 solid;
  min-height: 260px;
  padding: 10px;
  margin-bottom: 20px;
}
.results .rsp_career .result-media.hasthumb {
  padding:0;
  border:none;
}
.results .result-media {
  position: relative;
}
.results .result-media h2 {
  line-height: 32px;
  margin-bottom: 40px;
}
.results .result-category {
  position: absolute;
  bottom:10px;
}

  @media screen and (min-width: 768px) {
	.results { } }
  @media screen and (min-width: 960px) {
	.results { } }
/* ---------------------------------------------------------------------
 Combo
------------------------------------------------------------------------ */
.combo,
.combo > * {
  display: block;
  overflow: hidden; }

.combo-media {
  margin-bottom: 10px; }

.combo-heading {
  margin-bottom: 5px;
  font-size: 22px; }

@media screen and (min-width: 768px) {
  .combo-media {
	margin: 0 15px 0 0;
	width: 36.4556%;
	float: left; } }
/* ---------------------------------------------------------------------
 Category
------------------------------------------------------------------------ */
.category-heading {
  margin-bottom: 5px;
  font-size: 18px; }

.category-list > * {
  font-size: 12px; }

.category-list > * > * {
  font-size: 12px;
  color: #000000;
  text-decoration: underline; }

.category-list > * > *:hover {
  color: #666666; }

/* ---------------------------------------------------------------------
 Vertical List
------------------------------------------------------------------------ */
.vList > * {
  margin-top: 10px; }

/* ---------------------------------------------------------------------
 Spinner
------------------------------------------------------------------------ */
.spinner {
  display: none;
  margin: 20px auto; }

/* ---------------------------------------------------------------------
 Breadcrumbs container div
------------------------------------------------------------------------ */
.breadcrumbs {
  height: 20px;
  width: 100%;
  clear: both;
  color: #FFF;
  font-size: 12px;
  background-color: #000;
  background-color: rgba(0, 0, 0, 0.5);
  position: relative;
  bottom: 12px;
  line-height: normal;
  z-index: 999;
}

.breadcrumbs.article {
  bottom:0;
}
.breadcrumbs span {
  line-height: 20px;
}
.no-hero .breadcrumbs,
.breadcrumbs.fixed {
	position: fixed;
	top: 50px;
}
body.admin-bar .no-hero .breadcrumbs,
body.admin-bar .breadcrumbs.fixed {
	position: fixed;
	top: 82px;
}

.no-hero .site-inner {
	position: relative;
  top: 80px;
  margin-bottom: 80px;
}
@media screen and (max-width: 782px) {
	body.admin-bar .no-hero .breadcrumbs,
	body.admin-bar .breadcrumbs.fixed {
		position: fixed;
		top: 84px;
	}
}
@media screen and (min-width: 960px) {
  .breadcrumbs {
	bottom: 22px;
	height: 30px;
	line-height: 30px;
  }
  .breadcrumbs.article {
	bottom:0;
  }

}

/* ---------------------------------------------------------------------
 Utility
------------------------------------------------------------------------ */
.screen-reader-text,
.isVisuallyHidden {
  margin: -1px;
  padding: 0;
  border: 0;
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0 0 0 0);
  overflow: hidden; }
/* ---------------------------------------------------------------------
 Swipebox
------------------------------------------------------------------------ */
body .nivo-lightbox-image img {
  display: inline;
}
body .nivo-lightbox-theme-default.nivo-lightbox-overlay {
	background: #666;
	background: rgba(0,0,0,0.9);
}
/* ---------------------------------------------------------------------
 "Other" Styles - these don't quite fit the FED's ideals
------------------------------------------------------------------------ */
.contact-details {
  text-align: center; }

.career-link {
  text-align: center;
  margin-top: 40px;
  margin-bottom: 10px;
}

.rsp_career .col-row {
	margin-bottom: 0;
}
a.button-link,
.entry a.button-link {
  padding: 10px 15px;
  background-color: #000;
  color: #FFF;
  text-decoration: none;
  text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.4);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), 0 1px 1px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), 0 1px 1px rgba(0, 0, 0, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), 0 1px 1px rgba(0, 0, 0, 0.2); }

a.button-link:hover,
a.button-link:focus,
.entry a.button-link:hover,
.entry a.button-link:focus {
  background-color: #2f2f2f;
  color: #fdfdfd;
  text-decoration: none; }

a.button-link:active,
.entry a.button-link:active {
  -webkit-box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.6);
  -moz-box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.6);
  box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.6);
  background: #2E5481;
  border: solid 1px #203E5F; }

a.button-link {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

/* =Index pagination
-- */
/* The containing box with a nice white background */
.paging-navigation {
  font-family: sans-serif;
  padding: 1em;
  background: #fff;
  background: white; }

/* Remove bullets and list indentation */
.paging-navigation ul {
  list-style-type: none;
  margin: 0;
  padding: 0; }

/* Make the list items appear horizontally */
.paging-navigation li {
  display: inline; }

/* Give each link and the current item some padding to make them easy to click */
a.page-numbers,
span.page-numbers {
  padding: .3em .7em;
  color: #333;
  color: #333333; }

/* Link hover state */
a:hover.page-numbers {
  color: #000;
  color: black;
}

/* Current page bold and dark */
.paging-navigation .current {
  font-weight: bold;
  color: #000;
  color: black; }

/** sprite icons */
.sprite {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACQAAAAQCAYAAAB+690jAAADaklEQVRIS82UXWhcRRTH/zPZ3SwrVCui7pvig9/EFqVIQcQPUFu1kkKpiiSSnTM3S0PxobSgcJGiIBUkGnNndiGRoiA02vr1FAvFh9qCiijom30qtSC2hdLsevccmbJ3udnuSoognrc795z//Q3zu6PwPysVeJxzfwC4/l+yfUdE9+cz4jguxHGcZmvOuW8BjAH4VUSWRkdH35ucnDyXn8mABMASM0+Xy+X21YCtrKyUtNbvAxgnost5oZIkeVEp1RSR3dbaJKx57+8DsFFENgHYAeAvpdROY8xyNpcH+gnAeWYej6Lo7FqgnHM3iMgnSqn1AO7JgJIkeUop9TkA3c2xROSSJNkFoDoyMrLcarV+LBaLTQBbReQJa+3XobcHlKZptVAovA1gM4CniSgADi3v/d0i8gWAcAyvADidATnnjgF4KDfcIqKyc+5AAABwe5gtFovPdzqdgyKyudVq3TYzM3OhB1QqldZPTEyc997vA7BXRF6w1oZdXlHe+7CrDwEcMMbsX1xcvLbdbv+ZA/oKwJO5wWkims+evfePicjHIrKslKoD+E0p9YYx5s1VQJlg3vvnROQDAPuJ6K08kXNuD4BXReRla+2h8G5hYeG6PFCSJI8qpTIvWCn1kjEmbKBX3vtxETmktR5j5t0A7iWiBwYChan5+fkNWusjAI6VSqVd7XY7iP8ugIeZ+dkoin7I0vuBulLPKaWmuz0sIjuyDYS1OI51tVoNf/frAC4CeIeIKkOBco4wgFu6wacAjPQ7NgjIOVcB8H3wpTsb/qjtxpjPckd3mJmPaK1/FpGDRHTHQCDn3BYAH2WONJvNG0PI1NTU2UGODQIK/Y1G405mDtKvGwbVL+gVQJkjSqlJY8zSEKlXOTYMqAv1CDN/CaCchxKRBwHUAGwhohPZd3pAzHyT1joIHAJWOTIIKufYUWbeo7X+PX8x5mcajUbIDEd1TXc9+JhdoheY+fEoik6Gd/mLMUjaTtN0W71ePzMIon9tbm7u5kKhcBhACcCGYUBdyceUUp8CuLU/R0S+sdZevrd6QOGi6nQ6tUqlsrIWmKwnTdNRZvYAnvknoNA/Ozu7rlwuJyKyM/eNS1rrrbVa7WgeKJBvuxqQAb2/ENFda8lIkmS71rouIh0Rec1ae3yVQ2sJ+a96/gY/o9sgtrx8rAAAAABJRU5ErkJggg==);
  background-repeat: no-repeat;
  display: inline-block; }

.sprite-icon-email {
  width: 18px;
  height: 14px;
  background-position: -1px -1px; }

.sprite-icon-phone {
  width: 14px;
  height: 14px;
  background-position: -21px -1px; }

/* Definition lists */
dl dt {
  font-weight: bold; }

dl dd {
  margin-bottom: 1.618em; }

/* Tables */
table {
  border-spacing: 0;
  width: 100%;
  border: 1px solid #b9b9b9;
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  background: #f9f9f9;
  box-shadow: 0 1px 2px 0 #ffffff;
  -webkit-box-shadow: 0 1px 2px 0 #ffffff;
  border-collapse: separate; }

table td,
table th {
  padding: .857em 1.387em;
  text-align: left;
  border-right: 1px dotted #b9b9b9;
  vertical-align: top; }

table td p:last-child,
table th p:last-child {
  margin-bottom: 0; }

table thead th {
  background: #fff;
  border-right: 1px dotted #b9b9b9;
  border-bottom: 2px solid #b9b9b9;
  text-transform: uppercase;
  padding: 1.387em;
  vertical-align: middle;
  color: #e8e8e8; }

table thead th:first-child {
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box; }

table thead th:last-child {
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box; }

table tr th:last-child,
table tr td:last-child {
  border-right: 0; }

table tbody th {
  background: #fff;
  border-bottom: 1px solid #b9b9b9; }

table tbody tr:nth-child(2n) td {
  background: #f9f9f9;
  border-right: 1px dotted #b9b9b9; }

table tbody tr:nth-child(2n) td:last-child {
  border-right: 0; }

table tbody td {
  background: #fff;
  vertical-align: middle;
  border-bottom: 1px solid #b9b9b9;
  -webkit-box-shadow: inset 0 1px 0 0 #f9f9f9, inset 0 -1px 0 #ffffff;
  box-shadow: inset 0 1px 0 0 #f9f9f9, inset 0 -1px 0 #ffffff; }

table tbody h2 {
  font-size: 1em;
  letter-spacing: normal;
  font-weight: normal; }

table tbody h2 a {
  font-weight: normal; }

table tbody tr:last-child td:first-child {
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box; }

table tbody tr:last-child td:last-child {
  -moz-background-clip: padding;
  -webkit-background-clip: padding-box;
  background-clip: padding-box; }

table tbody tr:last-child td {
  border-bottom: 0; }

table tfoot th {
  color: #e8e8e8;
  background: #fff;
  border-top: 1px solid #b9b9b9; }

table tfoot td {
  background: #fff;
  border-top: 1px solid #b9b9b9; }

.opaque:after {
	content:'\A';
	position:absolute;
	width:100%; height:100%;
	top:0; left:0;
	opacity:0;
}
.opaque:after {
	content:'\A';
	position:absolute;
	width:100%; height:100%;
	top:0; left:0;
	opacity:1;
	transition: all 0.2s;
	-webkit-transition: all 0.2s;
}
.ismobile .opaque-wrap .opaque:after,
.opaque-wrap:hover .opaque:after {
	background: rgba(0,0,0,0.4);
}

.single-location .google-map-wrap {
	position: relative;
}

.single-location .google-map-wrap .place-card {
	position: absolute;
	top: 5px;
	left: 5px;
	background-color: #fff;
	padding: 8px;
	width: 250px;
	font-size: 12px;
}

.single-location .google-map-wrap .place-card .map-link {
	color: #3a84df;
}

.single-location .google-map-wrap .place-card .map-address,
.single-location .google-map-wrap .place-card .map-title {
	margin-bottom: 5px;
}
.single-location .google-map-wrap .place-card .map-title {
	font-size: 14px;
	font-weight: bold;
}
.single-location .google-map-wrap .place-card ul {
	padding: 0;
}

.single-location .google-map-wrap .place-card ul li {
	list-style-type: none;
}

.single-location .google-map {
	height: 400px;
}
